diff options
| author | Maximilian Hils <git@maximilianhils.com> | 2015-09-07 10:30:40 +0200 | 
|---|---|---|
| committer | Maximilian Hils <git@maximilianhils.com> | 2015-09-07 10:30:40 +0200 | 
| commit | 31ee4607c892f85c5d139e54acbc3ca4f9fb6bcb (patch) | |
| tree | 873629c79b60b0ac0a7dbb458fe6ad82c2e042ef | |
| parent | b4013659a81a48908eb3e060f04143ba1f9689bb (diff) | |
| download | mitmproxy-31ee4607c892f85c5d139e54acbc3ca4f9fb6bcb.tar.gz mitmproxy-31ee4607c892f85c5d139e54acbc3ca4f9fb6bcb.tar.bz2 mitmproxy-31ee4607c892f85c5d139e54acbc3ca4f9fb6bcb.zip | |
remove old docs
107 files changed, 0 insertions, 9380 deletions
| diff --git a/doc-src/01-vendor.css b/doc-src/01-vendor.css deleted file mode 100644 index 9c97647a..00000000 --- a/doc-src/01-vendor.css +++ /dev/null @@ -1,6706 +0,0 @@ -.navbar-inverse .badge { -  background-color: #fff; -  color: #2780e3; -} -body { -  -webkit-font-smoothing: antialiased; -} -.text-primary, -.text-primary:hover { -  color: #2780e3; -} -.text-success, -.text-success:hover { -  color: #3fb618; -} -.text-danger, -.text-danger:hover { -  color: #ff0039; -} -.text-warning, -.text-warning:hover { -  color: #ff7518; -} -.text-info, -.text-info:hover { -  color: #9954bb; -} -table a:not(.btn), -.table a:not(.btn) { -  text-decoration: underline; -} -table .dropdown-menu a, -.table .dropdown-menu a { -  text-decoration: none; -} -table .success, -.table .success, -table .warning, -.table .warning, -table .danger, -.table .danger, -table .info, -.table .info { -  color: #fff; -} -table .success a, -.table .success a, -table .warning a, -.table .warning a, -table .danger a, -.table .danger a, -table .info a, -.table .info a { -  color: #fff; -} -.has-warning .help-block, -.has-warning .control-label, -.has-warning .form-control-feedback { -  color: #ff7518; -} -.has-warning .form-control, -.has-warning .form-control:focus, -.has-warning .input-group-addon { -  border: 1px solid #ff7518; -} -.has-error .help-block, -.has-error .control-label, -.has-error .form-control-feedback { -  color: #ff0039; -} -.has-error .form-control, -.has-error .form-control:focus, -.has-error .input-group-addon { -  border: 1px solid #ff0039; -} -.has-success .help-block, -.has-success .control-label, -.has-success .form-control-feedback { -  color: #3fb618; -} -.has-success .form-control, -.has-success .form-control:focus, -.has-success .input-group-addon { -  border: 1px solid #3fb618; -} -.nav-pills > li > a { -  border-radius: 0; -} -.dropdown-menu > li > a:hover, -.dropdown-menu > li > a:focus { -  background-image: none; -} -.close { -  text-decoration: none; -  text-shadow: none; -  opacity: 0.4; -} -.close:hover, -.close:focus { -  opacity: 1; -} -.alert { -  border: none; -} -.alert .alert-link { -  text-decoration: underline; -  color: #fff; -} -.label { -  border-radius: 0; -} -.progress { -  height: 8px; -  -webkit-box-shadow: none; -  box-shadow: none; -} -.progress .progress-bar { -  font-size: 8px; -  line-height: 8px; -} -.panel-heading, -.panel-footer { -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.panel-default .close { -  color: #333333; -} -a.list-group-item-success.active { -  background-color: #3fb618; -} -a.list-group-item-success.active:hover, -a.list-group-item-success.active:focus { -  background-color: #379f15; -} -a.list-group-item-warning.active { -  background-color: #ff7518; -} -a.list-group-item-warning.active:hover, -a.list-group-item-warning.active:focus { -  background-color: #fe6600; -} -a.list-group-item-danger.active { -  background-color: #ff0039; -} -a.list-group-item-danger.active:hover, -a.list-group-item-danger.active:focus { -  background-color: #e60033; -} -.modal .close { -  color: #333333; -} -.popover { -  color: #333333; -} -/*! normalize.css v3.0.2 | MIT License | git.io/normalize */ -html { -  font-family: sans-serif; -  -ms-text-size-adjust: 100%; -  -webkit-text-size-adjust: 100%; -} -body { -  margin: 0; -} -article, -aside, -details, -figcaption, -figure, -footer, -header, -hgroup, -main, -menu, -nav, -section, -summary { -  display: block; -} -audio, -canvas, -progress, -video { -  display: inline-block; -  vertical-align: baseline; -} -audio:not([controls]) { -  display: none; -  height: 0; -} -[hidden], -template { -  display: none; -} -a { -  background-color: transparent; -} -a:active, -a:hover { -  outline: 0; -} -abbr[title] { -  border-bottom: 1px dotted; -} -b, -strong { -  font-weight: bold; -} -dfn { -  font-style: italic; -} -h1 { -  font-size: 2em; -  margin: 0.67em 0; -} -mark { -  background: #ff0; -  color: #000; -} -small { -  font-size: 80%; -} -sub, -sup { -  font-size: 75%; -  line-height: 0; -  position: relative; -  vertical-align: baseline; -} -sup { -  top: -0.5em; -} -sub { -  bottom: -0.25em; -} -img { -  border: 0; -} -svg:not(:root) { -  overflow: hidden; -} -figure { -  margin: 1em 40px; -} -hr { -  -moz-box-sizing: content-box; -  box-sizing: content-box; -  height: 0; -} -pre { -  overflow: auto; -} -code, -kbd, -pre, -samp { -  font-family: monospace, monospace; -  font-size: 1em; -} -button, -input, -optgroup, -select, -textarea { -  color: inherit; -  font: inherit; -  margin: 0; -} -button { -  overflow: visible; -} -button, -select { -  text-transform: none; -} -button, -html input[type="button"], -input[type="reset"], -input[type="submit"] { -  -webkit-appearance: button; -  cursor: pointer; -} -button[disabled], -html input[disabled] { -  cursor: default; -} -button::-moz-focus-inner, -input::-moz-focus-inner { -  border: 0; -  padding: 0; -} -input { -  line-height: normal; -} -input[type="checkbox"], -input[type="radio"] { -  box-sizing: border-box; -  padding: 0; -} -input[type="number"]::-webkit-inner-spin-button, -input[type="number"]::-webkit-outer-spin-button { -  height: auto; -} -input[type="search"] { -  -webkit-appearance: textfield; -  -moz-box-sizing: content-box; -  -webkit-box-sizing: content-box; -  box-sizing: content-box; -} -input[type="search"]::-webkit-search-cancel-button, -input[type="search"]::-webkit-search-decoration { -  -webkit-appearance: none; -} -fieldset { -  border: 1px solid #c0c0c0; -  margin: 0 2px; -  padding: 0.35em 0.625em 0.75em; -} -legend { -  border: 0; -  padding: 0; -} -textarea { -  overflow: auto; -} -optgroup { -  font-weight: bold; -} -table { -  border-collapse: collapse; -  border-spacing: 0; -} -td, -th { -  padding: 0; -} -/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */ -@media print { -  *, -  *:before, -  *:after { -    background: transparent !important; -    color: #000 !important; -    box-shadow: none !important; -    text-shadow: none !important; -  } -  a, -  a:visited { -    text-decoration: underline; -  } -  a[href]:after { -    content: " (" attr(href) ")"; -  } -  abbr[title]:after { -    content: " (" attr(title) ")"; -  } -  a[href^="#"]:after, -  a[href^="javascript:"]:after { -    content: ""; -  } -  pre, -  blockquote { -    border: 1px solid #999; -    page-break-inside: avoid; -  } -  thead { -    display: table-header-group; -  } -  tr, -  img { -    page-break-inside: avoid; -  } -  img { -    max-width: 100% !important; -  } -  p, -  h2, -  h3 { -    orphans: 3; -    widows: 3; -  } -  h2, -  h3 { -    page-break-after: avoid; -  } -  select { -    background: #fff !important; -  } -  .navbar { -    display: none; -  } -  .btn > .caret, -  .dropup > .btn > .caret { -    border-top-color: #000 !important; -  } -  .label { -    border: 1px solid #000; -  } -  .table { -    border-collapse: collapse !important; -  } -  .table td, -  .table th { -    background-color: #fff !important; -  } -  .table-bordered th, -  .table-bordered td { -    border: 1px solid #ddd !important; -  } -} -@font-face { -  font-family: 'Glyphicons Halflings'; -  src: url('../fonts/glyphicons-halflings-regular.eot'); -  src: url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/glyphicons-halflings-regular.woff2') format('woff2'), url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'), url('../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular') format('svg'); -} -.glyphicon { -  position: relative; -  top: 1px; -  display: inline-block; -  font-family: 'Glyphicons Halflings'; -  font-style: normal; -  font-weight: normal; -  line-height: 1; -  -webkit-font-smoothing: antialiased; -  -moz-osx-font-smoothing: grayscale; -} -.glyphicon-asterisk:before { -  content: "\2a"; -} -.glyphicon-plus:before { -  content: "\2b"; -} -.glyphicon-euro:before, -.glyphicon-eur:before { -  content: "\20ac"; -} -.glyphicon-minus:before { -  content: "\2212"; -} -.glyphicon-cloud:before { -  content: "\2601"; -} -.glyphicon-envelope:before { -  content: "\2709"; -} -.glyphicon-pencil:before { -  content: "\270f"; -} -.glyphicon-glass:before { -  content: "\e001"; -} -.glyphicon-music:before { -  content: "\e002"; -} -.glyphicon-search:before { -  content: "\e003"; -} -.glyphicon-heart:before { -  content: "\e005"; -} -.glyphicon-star:before { -  content: "\e006"; -} -.glyphicon-star-empty:before { -  content: "\e007"; -} -.glyphicon-user:before { -  content: "\e008"; -} -.glyphicon-film:before { -  content: "\e009"; -} -.glyphicon-th-large:before { -  content: "\e010"; -} -.glyphicon-th:before { -  content: "\e011"; -} -.glyphicon-th-list:before { -  content: "\e012"; -} -.glyphicon-ok:before { -  content: "\e013"; -} -.glyphicon-remove:before { -  content: "\e014"; -} -.glyphicon-zoom-in:before { -  content: "\e015"; -} -.glyphicon-zoom-out:before { -  content: "\e016"; -} -.glyphicon-off:before { -  content: "\e017"; -} -.glyphicon-signal:before { -  content: "\e018"; -} -.glyphicon-cog:before { -  content: "\e019"; -} -.glyphicon-trash:before { -  content: "\e020"; -} -.glyphicon-home:before { -  content: "\e021"; -} -.glyphicon-file:before { -  content: "\e022"; -} -.glyphicon-time:before { -  content: "\e023"; -} -.glyphicon-road:before { -  content: "\e024"; -} -.glyphicon-download-alt:before { -  content: "\e025"; -} -.glyphicon-download:before { -  content: "\e026"; -} -.glyphicon-upload:before { -  content: "\e027"; -} -.glyphicon-inbox:before { -  content: "\e028"; -} -.glyphicon-play-circle:before { -  content: "\e029"; -} -.glyphicon-repeat:before { -  content: "\e030"; -} -.glyphicon-refresh:before { -  content: "\e031"; -} -.glyphicon-list-alt:before { -  content: "\e032"; -} -.glyphicon-lock:before { -  content: "\e033"; -} -.glyphicon-flag:before { -  content: "\e034"; -} -.glyphicon-headphones:before { -  content: "\e035"; -} -.glyphicon-volume-off:before { -  content: "\e036"; -} -.glyphicon-volume-down:before { -  content: "\e037"; -} -.glyphicon-volume-up:before { -  content: "\e038"; -} -.glyphicon-qrcode:before { -  content: "\e039"; -} -.glyphicon-barcode:before { -  content: "\e040"; -} -.glyphicon-tag:before { -  content: "\e041"; -} -.glyphicon-tags:before { -  content: "\e042"; -} -.glyphicon-book:before { -  content: "\e043"; -} -.glyphicon-bookmark:before { -  content: "\e044"; -} -.glyphicon-print:before { -  content: "\e045"; -} -.glyphicon-camera:before { -  content: "\e046"; -} -.glyphicon-font:before { -  content: "\e047"; -} -.glyphicon-bold:before { -  content: "\e048"; -} -.glyphicon-italic:before { -  content: "\e049"; -} -.glyphicon-text-height:before { -  content: "\e050"; -} -.glyphicon-text-width:before { -  content: "\e051"; -} -.glyphicon-align-left:before { -  content: "\e052"; -} -.glyphicon-align-center:before { -  content: "\e053"; -} -.glyphicon-align-right:before { -  content: "\e054"; -} -.glyphicon-align-justify:before { -  content: "\e055"; -} -.glyphicon-list:before { -  content: "\e056"; -} -.glyphicon-indent-left:before { -  content: "\e057"; -} -.glyphicon-indent-right:before { -  content: "\e058"; -} -.glyphicon-facetime-video:before { -  content: "\e059"; -} -.glyphicon-picture:before { -  content: "\e060"; -} -.glyphicon-map-marker:before { -  content: "\e062"; -} -.glyphicon-adjust:before { -  content: "\e063"; -} -.glyphicon-tint:before { -  content: "\e064"; -} -.glyphicon-edit:before { -  content: "\e065"; -} -.glyphicon-share:before { -  content: "\e066"; -} -.glyphicon-check:before { -  content: "\e067"; -} -.glyphicon-move:before { -  content: "\e068"; -} -.glyphicon-step-backward:before { -  content: "\e069"; -} -.glyphicon-fast-backward:before { -  content: "\e070"; -} -.glyphicon-backward:before { -  content: "\e071"; -} -.glyphicon-play:before { -  content: "\e072"; -} -.glyphicon-pause:before { -  content: "\e073"; -} -.glyphicon-stop:before { -  content: "\e074"; -} -.glyphicon-forward:before { -  content: "\e075"; -} -.glyphicon-fast-forward:before { -  content: "\e076"; -} -.glyphicon-step-forward:before { -  content: "\e077"; -} -.glyphicon-eject:before { -  content: "\e078"; -} -.glyphicon-chevron-left:before { -  content: "\e079"; -} -.glyphicon-chevron-right:before { -  content: "\e080"; -} -.glyphicon-plus-sign:before { -  content: "\e081"; -} -.glyphicon-minus-sign:before { -  content: "\e082"; -} -.glyphicon-remove-sign:before { -  content: "\e083"; -} -.glyphicon-ok-sign:before { -  content: "\e084"; -} -.glyphicon-question-sign:before { -  content: "\e085"; -} -.glyphicon-info-sign:before { -  content: "\e086"; -} -.glyphicon-screenshot:before { -  content: "\e087"; -} -.glyphicon-remove-circle:before { -  content: "\e088"; -} -.glyphicon-ok-circle:before { -  content: "\e089"; -} -.glyphicon-ban-circle:before { -  content: "\e090"; -} -.glyphicon-arrow-left:before { -  content: "\e091"; -} -.glyphicon-arrow-right:before { -  content: "\e092"; -} -.glyphicon-arrow-up:before { -  content: "\e093"; -} -.glyphicon-arrow-down:before { -  content: "\e094"; -} -.glyphicon-share-alt:before { -  content: "\e095"; -} -.glyphicon-resize-full:before { -  content: "\e096"; -} -.glyphicon-resize-small:before { -  content: "\e097"; -} -.glyphicon-exclamation-sign:before { -  content: "\e101"; -} -.glyphicon-gift:before { -  content: "\e102"; -} -.glyphicon-leaf:before { -  content: "\e103"; -} -.glyphicon-fire:before { -  content: "\e104"; -} -.glyphicon-eye-open:before { -  content: "\e105"; -} -.glyphicon-eye-close:before { -  content: "\e106"; -} -.glyphicon-warning-sign:before { -  content: "\e107"; -} -.glyphicon-plane:before { -  content: "\e108"; -} -.glyphicon-calendar:before { -  content: "\e109"; -} -.glyphicon-random:before { -  content: "\e110"; -} -.glyphicon-comment:before { -  content: "\e111"; -} -.glyphicon-magnet:before { -  content: "\e112"; -} -.glyphicon-chevron-up:before { -  content: "\e113"; -} -.glyphicon-chevron-down:before { -  content: "\e114"; -} -.glyphicon-retweet:before { -  content: "\e115"; -} -.glyphicon-shopping-cart:before { -  content: "\e116"; -} -.glyphicon-folder-close:before { -  content: "\e117"; -} -.glyphicon-folder-open:before { -  content: "\e118"; -} -.glyphicon-resize-vertical:before { -  content: "\e119"; -} -.glyphicon-resize-horizontal:before { -  content: "\e120"; -} -.glyphicon-hdd:before { -  content: "\e121"; -} -.glyphicon-bullhorn:before { -  content: "\e122"; -} -.glyphicon-bell:before { -  content: "\e123"; -} -.glyphicon-certificate:before { -  content: "\e124"; -} -.glyphicon-thumbs-up:before { -  content: "\e125"; -} -.glyphicon-thumbs-down:before { -  content: "\e126"; -} -.glyphicon-hand-right:before { -  content: "\e127"; -} -.glyphicon-hand-left:before { -  content: "\e128"; -} -.glyphicon-hand-up:before { -  content: "\e129"; -} -.glyphicon-hand-down:before { -  content: "\e130"; -} -.glyphicon-circle-arrow-right:before { -  content: "\e131"; -} -.glyphicon-circle-arrow-left:before { -  content: "\e132"; -} -.glyphicon-circle-arrow-up:before { -  content: "\e133"; -} -.glyphicon-circle-arrow-down:before { -  content: "\e134"; -} -.glyphicon-globe:before { -  content: "\e135"; -} -.glyphicon-wrench:before { -  content: "\e136"; -} -.glyphicon-tasks:before { -  content: "\e137"; -} -.glyphicon-filter:before { -  content: "\e138"; -} -.glyphicon-briefcase:before { -  content: "\e139"; -} -.glyphicon-fullscreen:before { -  content: "\e140"; -} -.glyphicon-dashboard:before { -  content: "\e141"; -} -.glyphicon-paperclip:before { -  content: "\e142"; -} -.glyphicon-heart-empty:before { -  content: "\e143"; -} -.glyphicon-link:before { -  content: "\e144"; -} -.glyphicon-phone:before { -  content: "\e145"; -} -.glyphicon-pushpin:before { -  content: "\e146"; -} -.glyphicon-usd:before { -  content: "\e148"; -} -.glyphicon-gbp:before { -  content: "\e149"; -} -.glyphicon-sort:before { -  content: "\e150"; -} -.glyphicon-sort-by-alphabet:before { -  content: "\e151"; -} -.glyphicon-sort-by-alphabet-alt:before { -  content: "\e152"; -} -.glyphicon-sort-by-order:before { -  content: "\e153"; -} -.glyphicon-sort-by-order-alt:before { -  content: "\e154"; -} -.glyphicon-sort-by-attributes:before { -  content: "\e155"; -} -.glyphicon-sort-by-attributes-alt:before { -  content: "\e156"; -} -.glyphicon-unchecked:before { -  content: "\e157"; -} -.glyphicon-expand:before { -  content: "\e158"; -} -.glyphicon-collapse-down:before { -  content: "\e159"; -} -.glyphicon-collapse-up:before { -  content: "\e160"; -} -.glyphicon-log-in:before { -  content: "\e161"; -} -.glyphicon-flash:before { -  content: "\e162"; -} -.glyphicon-log-out:before { -  content: "\e163"; -} -.glyphicon-new-window:before { -  content: "\e164"; -} -.glyphicon-record:before { -  content: "\e165"; -} -.glyphicon-save:before { -  content: "\e166"; -} -.glyphicon-open:before { -  content: "\e167"; -} -.glyphicon-saved:before { -  content: "\e168"; -} -.glyphicon-import:before { -  content: "\e169"; -} -.glyphicon-export:before { -  content: "\e170"; -} -.glyphicon-send:before { -  content: "\e171"; -} -.glyphicon-floppy-disk:before { -  content: "\e172"; -} -.glyphicon-floppy-saved:before { -  content: "\e173"; -} -.glyphicon-floppy-remove:before { -  content: "\e174"; -} -.glyphicon-floppy-save:before { -  content: "\e175"; -} -.glyphicon-floppy-open:before { -  content: "\e176"; -} -.glyphicon-credit-card:before { -  content: "\e177"; -} -.glyphicon-transfer:before { -  content: "\e178"; -} -.glyphicon-cutlery:before { -  content: "\e179"; -} -.glyphicon-header:before { -  content: "\e180"; -} -.glyphicon-compressed:before { -  content: "\e181"; -} -.glyphicon-earphone:before { -  content: "\e182"; -} -.glyphicon-phone-alt:before { -  content: "\e183"; -} -.glyphicon-tower:before { -  content: "\e184"; -} -.glyphicon-stats:before { -  content: "\e185"; -} -.glyphicon-sd-video:before { -  content: "\e186"; -} -.glyphicon-hd-video:before { -  content: "\e187"; -} -.glyphicon-subtitles:before { -  content: "\e188"; -} -.glyphicon-sound-stereo:before { -  content: "\e189"; -} -.glyphicon-sound-dolby:before { -  content: "\e190"; -} -.glyphicon-sound-5-1:before { -  content: "\e191"; -} -.glyphicon-sound-6-1:before { -  content: "\e192"; -} -.glyphicon-sound-7-1:before { -  content: "\e193"; -} -.glyphicon-copyright-mark:before { -  content: "\e194"; -} -.glyphicon-registration-mark:before { -  content: "\e195"; -} -.glyphicon-cloud-download:before { -  content: "\e197"; -} -.glyphicon-cloud-upload:before { -  content: "\e198"; -} -.glyphicon-tree-conifer:before { -  content: "\e199"; -} -.glyphicon-tree-deciduous:before { -  content: "\e200"; -} -.glyphicon-cd:before { -  content: "\e201"; -} -.glyphicon-save-file:before { -  content: "\e202"; -} -.glyphicon-open-file:before { -  content: "\e203"; -} -.glyphicon-level-up:before { -  content: "\e204"; -} -.glyphicon-copy:before { -  content: "\e205"; -} -.glyphicon-paste:before { -  content: "\e206"; -} -.glyphicon-alert:before { -  content: "\e209"; -} -.glyphicon-equalizer:before { -  content: "\e210"; -} -.glyphicon-king:before { -  content: "\e211"; -} -.glyphicon-queen:before { -  content: "\e212"; -} -.glyphicon-pawn:before { -  content: "\e213"; -} -.glyphicon-bishop:before { -  content: "\e214"; -} -.glyphicon-knight:before { -  content: "\e215"; -} -.glyphicon-baby-formula:before { -  content: "\e216"; -} -.glyphicon-tent:before { -  content: "\26fa"; -} -.glyphicon-blackboard:before { -  content: "\e218"; -} -.glyphicon-bed:before { -  content: "\e219"; -} -.glyphicon-apple:before { -  content: "\f8ff"; -} -.glyphicon-erase:before { -  content: "\e221"; -} -.glyphicon-hourglass:before { -  content: "\231b"; -} -.glyphicon-lamp:before { -  content: "\e223"; -} -.glyphicon-duplicate:before { -  content: "\e224"; -} -.glyphicon-piggy-bank:before { -  content: "\e225"; -} -.glyphicon-scissors:before { -  content: "\e226"; -} -.glyphicon-bitcoin:before { -  content: "\e227"; -} -.glyphicon-btc:before { -  content: "\e227"; -} -.glyphicon-xbt:before { -  content: "\e227"; -} -.glyphicon-yen:before { -  content: "\00a5"; -} -.glyphicon-jpy:before { -  content: "\00a5"; -} -.glyphicon-ruble:before { -  content: "\20bd"; -} -.glyphicon-rub:before { -  content: "\20bd"; -} -.glyphicon-scale:before { -  content: "\e230"; -} -.glyphicon-ice-lolly:before { -  content: "\e231"; -} -.glyphicon-ice-lolly-tasted:before { -  content: "\e232"; -} -.glyphicon-education:before { -  content: "\e233"; -} -.glyphicon-option-horizontal:before { -  content: "\e234"; -} -.glyphicon-option-vertical:before { -  content: "\e235"; -} -.glyphicon-menu-hamburger:before { -  content: "\e236"; -} -.glyphicon-modal-window:before { -  content: "\e237"; -} -.glyphicon-oil:before { -  content: "\e238"; -} -.glyphicon-grain:before { -  content: "\e239"; -} -.glyphicon-sunglasses:before { -  content: "\e240"; -} -.glyphicon-text-size:before { -  content: "\e241"; -} -.glyphicon-text-color:before { -  content: "\e242"; -} -.glyphicon-text-background:before { -  content: "\e243"; -} -.glyphicon-object-align-top:before { -  content: "\e244"; -} -.glyphicon-object-align-bottom:before { -  content: "\e245"; -} -.glyphicon-object-align-horizontal:before { -  content: "\e246"; -} -.glyphicon-object-align-left:before { -  content: "\e247"; -} -.glyphicon-object-align-vertical:before { -  content: "\e248"; -} -.glyphicon-object-align-right:before { -  content: "\e249"; -} -.glyphicon-triangle-right:before { -  content: "\e250"; -} -.glyphicon-triangle-left:before { -  content: "\e251"; -} -.glyphicon-triangle-bottom:before { -  content: "\e252"; -} -.glyphicon-triangle-top:before { -  content: "\e253"; -} -.glyphicon-console:before { -  content: "\e254"; -} -.glyphicon-superscript:before { -  content: "\e255"; -} -.glyphicon-subscript:before { -  content: "\e256"; -} -.glyphicon-menu-left:before { -  content: "\e257"; -} -.glyphicon-menu-right:before { -  content: "\e258"; -} -.glyphicon-menu-down:before { -  content: "\e259"; -} -.glyphicon-menu-up:before { -  content: "\e260"; -} -* { -  -webkit-box-sizing: border-box; -  -moz-box-sizing: border-box; -  box-sizing: border-box; -} -*:before, -*:after { -  -webkit-box-sizing: border-box; -  -moz-box-sizing: border-box; -  box-sizing: border-box; -} -html { -  font-size: 10px; -  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); -} -body { -  font-family: "Source Sans Pro", Calibri, Candara, Arial, sans-serif; -  font-size: 15px; -  line-height: 1.42857143; -  color: #333333; -  background-color: #ffffff; -} -input, -button, -select, -textarea { -  font-family: inherit; -  font-size: inherit; -  line-height: inherit; -} -a { -  color: #2780e3; -  text-decoration: none; -} -a:hover, -a:focus { -  color: #165ba8; -  text-decoration: underline; -} -a:focus { -  outline: thin dotted; -  outline: 5px auto -webkit-focus-ring-color; -  outline-offset: -2px; -} -figure { -  margin: 0; -} -img { -  vertical-align: middle; -} -.img-responsive, -.thumbnail > img, -.thumbnail a > img, -.carousel-inner > .item > img, -.carousel-inner > .item > a > img { -  display: block; -  max-width: 100%; -  height: auto; -} -.img-rounded { -  border-radius: 0; -} -.img-thumbnail { -  padding: 4px; -  line-height: 1.42857143; -  background-color: #ffffff; -  border: 1px solid #dddddd; -  border-radius: 0; -  -webkit-transition: all 0.2s ease-in-out; -  -o-transition: all 0.2s ease-in-out; -  transition: all 0.2s ease-in-out; -  display: inline-block; -  max-width: 100%; -  height: auto; -} -.img-circle { -  border-radius: 50%; -} -hr { -  margin-top: 21px; -  margin-bottom: 21px; -  border: 0; -  border-top: 1px solid #e6e6e6; -} -.sr-only { -  position: absolute; -  width: 1px; -  height: 1px; -  margin: -1px; -  padding: 0; -  overflow: hidden; -  clip: rect(0, 0, 0, 0); -  border: 0; -} -.sr-only-focusable:active, -.sr-only-focusable:focus { -  position: static; -  width: auto; -  height: auto; -  margin: 0; -  overflow: visible; -  clip: auto; -} -[role="button"] { -  cursor: pointer; -} -h1, -h2, -h3, -h4, -h5, -h6, -.h1, -.h2, -.h3, -.h4, -.h5, -.h6 { -  font-family: "Source Sans Pro", Calibri, Candara, Arial, sans-serif; -  font-weight: 300; -  line-height: 1.1; -  color: inherit; -} -h1 small, -h2 small, -h3 small, -h4 small, -h5 small, -h6 small, -.h1 small, -.h2 small, -.h3 small, -.h4 small, -.h5 small, -.h6 small, -h1 .small, -h2 .small, -h3 .small, -h4 .small, -h5 .small, -h6 .small, -.h1 .small, -.h2 .small, -.h3 .small, -.h4 .small, -.h5 .small, -.h6 .small { -  font-weight: normal; -  line-height: 1; -  color: #999999; -} -h1, -.h1, -h2, -.h2, -h3, -.h3 { -  margin-top: 21px; -  margin-bottom: 10.5px; -} -h1 small, -.h1 small, -h2 small, -.h2 small, -h3 small, -.h3 small, -h1 .small, -.h1 .small, -h2 .small, -.h2 .small, -h3 .small, -.h3 .small { -  font-size: 65%; -} -h4, -.h4, -h5, -.h5, -h6, -.h6 { -  margin-top: 10.5px; -  margin-bottom: 10.5px; -} -h4 small, -.h4 small, -h5 small, -.h5 small, -h6 small, -.h6 small, -h4 .small, -.h4 .small, -h5 .small, -.h5 .small, -h6 .small, -.h6 .small { -  font-size: 75%; -} -h1, -.h1 { -  font-size: 39px; -} -h2, -.h2 { -  font-size: 32px; -} -h3, -.h3 { -  font-size: 26px; -} -h4, -.h4 { -  font-size: 19px; -} -h5, -.h5 { -  font-size: 15px; -} -h6, -.h6 { -  font-size: 13px; -} -p { -  margin: 0 0 10.5px; -} -.lead { -  margin-bottom: 21px; -  font-size: 17px; -  font-weight: 300; -  line-height: 1.4; -} -@media (min-width: 768px) { -  .lead { -    font-size: 22.5px; -  } -} -small, -.small { -  font-size: 86%; -} -mark, -.mark { -  background-color: #ff7518; -  padding: .2em; -} -.text-left { -  text-align: left; -} -.text-right { -  text-align: right; -} -.text-center { -  text-align: center; -} -.text-justify { -  text-align: justify; -} -.text-nowrap { -  white-space: nowrap; -} -.text-lowercase { -  text-transform: lowercase; -} -.text-uppercase { -  text-transform: uppercase; -} -.text-capitalize { -  text-transform: capitalize; -} -.text-muted { -  color: #999999; -} -.text-primary { -  color: #2780e3; -} -a.text-primary:hover { -  color: #1967be; -} -.text-success { -  color: #ffffff; -} -a.text-success:hover { -  color: #e6e6e6; -} -.text-info { -  color: #ffffff; -} -a.text-info:hover { -  color: #e6e6e6; -} -.text-warning { -  color: #ffffff; -} -a.text-warning:hover { -  color: #e6e6e6; -} -.text-danger { -  color: #ffffff; -} -a.text-danger:hover { -  color: #e6e6e6; -} -.bg-primary { -  color: #fff; -  background-color: #2780e3; -} -a.bg-primary:hover { -  background-color: #1967be; -} -.bg-success { -  background-color: #3fb618; -} -a.bg-success:hover { -  background-color: #2f8912; -} -.bg-info { -  background-color: #9954bb; -} -a.bg-info:hover { -  background-color: #7e3f9d; -} -.bg-warning { -  background-color: #ff7518; -} -a.bg-warning:hover { -  background-color: #e45c00; -} -.bg-danger { -  background-color: #ff0039; -} -a.bg-danger:hover { -  background-color: #cc002e; -} -.page-header { -  padding-bottom: 9.5px; -  margin: 42px 0 21px; -  border-bottom: 1px solid #e6e6e6; -} -ul, -ol { -  margin-top: 0; -  margin-bottom: 10.5px; -} -ul ul, -ol ul, -ul ol, -ol ol { -  margin-bottom: 0; -} -.list-unstyled { -  padding-left: 0; -  list-style: none; -} -.list-inline { -  padding-left: 0; -  list-style: none; -  margin-left: -5px; -} -.list-inline > li { -  display: inline-block; -  padding-left: 5px; -  padding-right: 5px; -} -dl { -  margin-top: 0; -  margin-bottom: 21px; -} -dt, -dd { -  line-height: 1.42857143; -} -dt { -  font-weight: bold; -} -dd { -  margin-left: 0; -} -@media (min-width: 768px) { -  .dl-horizontal dt { -    float: left; -    width: 160px; -    clear: left; -    text-align: right; -    overflow: hidden; -    text-overflow: ellipsis; -    white-space: nowrap; -  } -  .dl-horizontal dd { -    margin-left: 180px; -  } -} -abbr[title], -abbr[data-original-title] { -  cursor: help; -  border-bottom: 1px dotted #999999; -} -.initialism { -  font-size: 90%; -  text-transform: uppercase; -} -blockquote { -  padding: 10.5px 21px; -  margin: 0 0 21px; -  font-size: 18.75px; -  border-left: 5px solid #e6e6e6; -} -blockquote p:last-child, -blockquote ul:last-child, -blockquote ol:last-child { -  margin-bottom: 0; -} -blockquote footer, -blockquote small, -blockquote .small { -  display: block; -  font-size: 80%; -  line-height: 1.42857143; -  color: #999999; -} -blockquote footer:before, -blockquote small:before, -blockquote .small:before { -  content: '\2014 \00A0'; -} -.blockquote-reverse, -blockquote.pull-right { -  padding-right: 15px; -  padding-left: 0; -  border-right: 5px solid #e6e6e6; -  border-left: 0; -  text-align: right; -} -.blockquote-reverse footer:before, -blockquote.pull-right footer:before, -.blockquote-reverse small:before, -blockquote.pull-right small:before, -.blockquote-reverse .small:before, -blockquote.pull-right .small:before { -  content: ''; -} -.blockquote-reverse footer:after, -blockquote.pull-right footer:after, -.blockquote-reverse small:after, -blockquote.pull-right small:after, -.blockquote-reverse .small:after, -blockquote.pull-right .small:after { -  content: '\00A0 \2014'; -} -address { -  margin-bottom: 21px; -  font-style: normal; -  line-height: 1.42857143; -} -code, -kbd, -pre, -samp { -  font-family: Menlo, Monaco, Consolas, "Courier New", monospace; -} -code { -  padding: 2px 4px; -  font-size: 90%; -  color: #c7254e; -  background-color: #f9f2f4; -  border-radius: 0; -} -kbd { -  padding: 2px 4px; -  font-size: 90%; -  color: #ffffff; -  background-color: #333333; -  border-radius: 0; -  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25); -} -kbd kbd { -  padding: 0; -  font-size: 100%; -  font-weight: bold; -  box-shadow: none; -} -pre { -  display: block; -  padding: 10px; -  margin: 0 0 10.5px; -  font-size: 14px; -  line-height: 1.42857143; -  word-break: break-all; -  word-wrap: break-word; -  color: #333333; -  background-color: #f5f5f5; -  border: 1px solid #cccccc; -  border-radius: 0; -} -pre code { -  padding: 0; -  font-size: inherit; -  color: inherit; -  white-space: pre-wrap; -  background-color: transparent; -  border-radius: 0; -} -.pre-scrollable { -  max-height: 340px; -  overflow-y: scroll; -} -.container { -  margin-right: auto; -  margin-left: auto; -  padding-left: 15px; -  padding-right: 15px; -} -@media (min-width: 768px) { -  .container { -    width: 750px; -  } -} -@media (min-width: 992px) { -  .container { -    width: 970px; -  } -} -@media (min-width: 1200px) { -  .container { -    width: 1170px; -  } -} -.container-fluid { -  margin-right: auto; -  margin-left: auto; -  padding-left: 15px; -  padding-right: 15px; -} -.row { -  margin-left: -15px; -  margin-right: -15px; -} -.col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 { -  position: relative; -  min-height: 1px; -  padding-left: 15px; -  padding-right: 15px; -} -.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 { -  float: left; -} -.col-xs-12 { -  width: 100%; -} -.col-xs-11 { -  width: 91.66666667%; -} -.col-xs-10 { -  width: 83.33333333%; -} -.col-xs-9 { -  width: 75%; -} -.col-xs-8 { -  width: 66.66666667%; -} -.col-xs-7 { -  width: 58.33333333%; -} -.col-xs-6 { -  width: 50%; -} -.col-xs-5 { -  width: 41.66666667%; -} -.col-xs-4 { -  width: 33.33333333%; -} -.col-xs-3 { -  width: 25%; -} -.col-xs-2 { -  width: 16.66666667%; -} -.col-xs-1 { -  width: 8.33333333%; -} -.col-xs-pull-12 { -  right: 100%; -} -.col-xs-pull-11 { -  right: 91.66666667%; -} -.col-xs-pull-10 { -  right: 83.33333333%; -} -.col-xs-pull-9 { -  right: 75%; -} -.col-xs-pull-8 { -  right: 66.66666667%; -} -.col-xs-pull-7 { -  right: 58.33333333%; -} -.col-xs-pull-6 { -  right: 50%; -} -.col-xs-pull-5 { -  right: 41.66666667%; -} -.col-xs-pull-4 { -  right: 33.33333333%; -} -.col-xs-pull-3 { -  right: 25%; -} -.col-xs-pull-2 { -  right: 16.66666667%; -} -.col-xs-pull-1 { -  right: 8.33333333%; -} -.col-xs-pull-0 { -  right: auto; -} -.col-xs-push-12 { -  left: 100%; -} -.col-xs-push-11 { -  left: 91.66666667%; -} -.col-xs-push-10 { -  left: 83.33333333%; -} -.col-xs-push-9 { -  left: 75%; -} -.col-xs-push-8 { -  left: 66.66666667%; -} -.col-xs-push-7 { -  left: 58.33333333%; -} -.col-xs-push-6 { -  left: 50%; -} -.col-xs-push-5 { -  left: 41.66666667%; -} -.col-xs-push-4 { -  left: 33.33333333%; -} -.col-xs-push-3 { -  left: 25%; -} -.col-xs-push-2 { -  left: 16.66666667%; -} -.col-xs-push-1 { -  left: 8.33333333%; -} -.col-xs-push-0 { -  left: auto; -} -.col-xs-offset-12 { -  margin-left: 100%; -} -.col-xs-offset-11 { -  margin-left: 91.66666667%; -} -.col-xs-offset-10 { -  margin-left: 83.33333333%; -} -.col-xs-offset-9 { -  margin-left: 75%; -} -.col-xs-offset-8 { -  margin-left: 66.66666667%; -} -.col-xs-offset-7 { -  margin-left: 58.33333333%; -} -.col-xs-offset-6 { -  margin-left: 50%; -} -.col-xs-offset-5 { -  margin-left: 41.66666667%; -} -.col-xs-offset-4 { -  margin-left: 33.33333333%; -} -.col-xs-offset-3 { -  margin-left: 25%; -} -.col-xs-offset-2 { -  margin-left: 16.66666667%; -} -.col-xs-offset-1 { -  margin-left: 8.33333333%; -} -.col-xs-offset-0 { -  margin-left: 0%; -} -@media (min-width: 768px) { -  .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 { -    float: left; -  } -  .col-sm-12 { -    width: 100%; -  } -  .col-sm-11 { -    width: 91.66666667%; -  } -  .col-sm-10 { -    width: 83.33333333%; -  } -  .col-sm-9 { -    width: 75%; -  } -  .col-sm-8 { -    width: 66.66666667%; -  } -  .col-sm-7 { -    width: 58.33333333%; -  } -  .col-sm-6 { -    width: 50%; -  } -  .col-sm-5 { -    width: 41.66666667%; -  } -  .col-sm-4 { -    width: 33.33333333%; -  } -  .col-sm-3 { -    width: 25%; -  } -  .col-sm-2 { -    width: 16.66666667%; -  } -  .col-sm-1 { -    width: 8.33333333%; -  } -  .col-sm-pull-12 { -    right: 100%; -  } -  .col-sm-pull-11 { -    right: 91.66666667%; -  } -  .col-sm-pull-10 { -    right: 83.33333333%; -  } -  .col-sm-pull-9 { -    right: 75%; -  } -  .col-sm-pull-8 { -    right: 66.66666667%; -  } -  .col-sm-pull-7 { -    right: 58.33333333%; -  } -  .col-sm-pull-6 { -    right: 50%; -  } -  .col-sm-pull-5 { -    right: 41.66666667%; -  } -  .col-sm-pull-4 { -    right: 33.33333333%; -  } -  .col-sm-pull-3 { -    right: 25%; -  } -  .col-sm-pull-2 { -    right: 16.66666667%; -  } -  .col-sm-pull-1 { -    right: 8.33333333%; -  } -  .col-sm-pull-0 { -    right: auto; -  } -  .col-sm-push-12 { -    left: 100%; -  } -  .col-sm-push-11 { -    left: 91.66666667%; -  } -  .col-sm-push-10 { -    left: 83.33333333%; -  } -  .col-sm-push-9 { -    left: 75%; -  } -  .col-sm-push-8 { -    left: 66.66666667%; -  } -  .col-sm-push-7 { -    left: 58.33333333%; -  } -  .col-sm-push-6 { -    left: 50%; -  } -  .col-sm-push-5 { -    left: 41.66666667%; -  } -  .col-sm-push-4 { -    left: 33.33333333%; -  } -  .col-sm-push-3 { -    left: 25%; -  } -  .col-sm-push-2 { -    left: 16.66666667%; -  } -  .col-sm-push-1 { -    left: 8.33333333%; -  } -  .col-sm-push-0 { -    left: auto; -  } -  .col-sm-offset-12 { -    margin-left: 100%; -  } -  .col-sm-offset-11 { -    margin-left: 91.66666667%; -  } -  .col-sm-offset-10 { -    margin-left: 83.33333333%; -  } -  .col-sm-offset-9 { -    margin-left: 75%; -  } -  .col-sm-offset-8 { -    margin-left: 66.66666667%; -  } -  .col-sm-offset-7 { -    margin-left: 58.33333333%; -  } -  .col-sm-offset-6 { -    margin-left: 50%; -  } -  .col-sm-offset-5 { -    margin-left: 41.66666667%; -  } -  .col-sm-offset-4 { -    margin-left: 33.33333333%; -  } -  .col-sm-offset-3 { -    margin-left: 25%; -  } -  .col-sm-offset-2 { -    margin-left: 16.66666667%; -  } -  .col-sm-offset-1 { -    margin-left: 8.33333333%; -  } -  .col-sm-offset-0 { -    margin-left: 0%; -  } -} -@media (min-width: 992px) { -  .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 { -    float: left; -  } -  .col-md-12 { -    width: 100%; -  } -  .col-md-11 { -    width: 91.66666667%; -  } -  .col-md-10 { -    width: 83.33333333%; -  } -  .col-md-9 { -    width: 75%; -  } -  .col-md-8 { -    width: 66.66666667%; -  } -  .col-md-7 { -    width: 58.33333333%; -  } -  .col-md-6 { -    width: 50%; -  } -  .col-md-5 { -    width: 41.66666667%; -  } -  .col-md-4 { -    width: 33.33333333%; -  } -  .col-md-3 { -    width: 25%; -  } -  .col-md-2 { -    width: 16.66666667%; -  } -  .col-md-1 { -    width: 8.33333333%; -  } -  .col-md-pull-12 { -    right: 100%; -  } -  .col-md-pull-11 { -    right: 91.66666667%; -  } -  .col-md-pull-10 { -    right: 83.33333333%; -  } -  .col-md-pull-9 { -    right: 75%; -  } -  .col-md-pull-8 { -    right: 66.66666667%; -  } -  .col-md-pull-7 { -    right: 58.33333333%; -  } -  .col-md-pull-6 { -    right: 50%; -  } -  .col-md-pull-5 { -    right: 41.66666667%; -  } -  .col-md-pull-4 { -    right: 33.33333333%; -  } -  .col-md-pull-3 { -    right: 25%; -  } -  .col-md-pull-2 { -    right: 16.66666667%; -  } -  .col-md-pull-1 { -    right: 8.33333333%; -  } -  .col-md-pull-0 { -    right: auto; -  } -  .col-md-push-12 { -    left: 100%; -  } -  .col-md-push-11 { -    left: 91.66666667%; -  } -  .col-md-push-10 { -    left: 83.33333333%; -  } -  .col-md-push-9 { -    left: 75%; -  } -  .col-md-push-8 { -    left: 66.66666667%; -  } -  .col-md-push-7 { -    left: 58.33333333%; -  } -  .col-md-push-6 { -    left: 50%; -  } -  .col-md-push-5 { -    left: 41.66666667%; -  } -  .col-md-push-4 { -    left: 33.33333333%; -  } -  .col-md-push-3 { -    left: 25%; -  } -  .col-md-push-2 { -    left: 16.66666667%; -  } -  .col-md-push-1 { -    left: 8.33333333%; -  } -  .col-md-push-0 { -    left: auto; -  } -  .col-md-offset-12 { -    margin-left: 100%; -  } -  .col-md-offset-11 { -    margin-left: 91.66666667%; -  } -  .col-md-offset-10 { -    margin-left: 83.33333333%; -  } -  .col-md-offset-9 { -    margin-left: 75%; -  } -  .col-md-offset-8 { -    margin-left: 66.66666667%; -  } -  .col-md-offset-7 { -    margin-left: 58.33333333%; -  } -  .col-md-offset-6 { -    margin-left: 50%; -  } -  .col-md-offset-5 { -    margin-left: 41.66666667%; -  } -  .col-md-offset-4 { -    margin-left: 33.33333333%; -  } -  .col-md-offset-3 { -    margin-left: 25%; -  } -  .col-md-offset-2 { -    margin-left: 16.66666667%; -  } -  .col-md-offset-1 { -    margin-left: 8.33333333%; -  } -  .col-md-offset-0 { -    margin-left: 0%; -  } -} -@media (min-width: 1200px) { -  .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 { -    float: left; -  } -  .col-lg-12 { -    width: 100%; -  } -  .col-lg-11 { -    width: 91.66666667%; -  } -  .col-lg-10 { -    width: 83.33333333%; -  } -  .col-lg-9 { -    width: 75%; -  } -  .col-lg-8 { -    width: 66.66666667%; -  } -  .col-lg-7 { -    width: 58.33333333%; -  } -  .col-lg-6 { -    width: 50%; -  } -  .col-lg-5 { -    width: 41.66666667%; -  } -  .col-lg-4 { -    width: 33.33333333%; -  } -  .col-lg-3 { -    width: 25%; -  } -  .col-lg-2 { -    width: 16.66666667%; -  } -  .col-lg-1 { -    width: 8.33333333%; -  } -  .col-lg-pull-12 { -    right: 100%; -  } -  .col-lg-pull-11 { -    right: 91.66666667%; -  } -  .col-lg-pull-10 { -    right: 83.33333333%; -  } -  .col-lg-pull-9 { -    right: 75%; -  } -  .col-lg-pull-8 { -    right: 66.66666667%; -  } -  .col-lg-pull-7 { -    right: 58.33333333%; -  } -  .col-lg-pull-6 { -    right: 50%; -  } -  .col-lg-pull-5 { -    right: 41.66666667%; -  } -  .col-lg-pull-4 { -    right: 33.33333333%; -  } -  .col-lg-pull-3 { -    right: 25%; -  } -  .col-lg-pull-2 { -    right: 16.66666667%; -  } -  .col-lg-pull-1 { -    right: 8.33333333%; -  } -  .col-lg-pull-0 { -    right: auto; -  } -  .col-lg-push-12 { -    left: 100%; -  } -  .col-lg-push-11 { -    left: 91.66666667%; -  } -  .col-lg-push-10 { -    left: 83.33333333%; -  } -  .col-lg-push-9 { -    left: 75%; -  } -  .col-lg-push-8 { -    left: 66.66666667%; -  } -  .col-lg-push-7 { -    left: 58.33333333%; -  } -  .col-lg-push-6 { -    left: 50%; -  } -  .col-lg-push-5 { -    left: 41.66666667%; -  } -  .col-lg-push-4 { -    left: 33.33333333%; -  } -  .col-lg-push-3 { -    left: 25%; -  } -  .col-lg-push-2 { -    left: 16.66666667%; -  } -  .col-lg-push-1 { -    left: 8.33333333%; -  } -  .col-lg-push-0 { -    left: auto; -  } -  .col-lg-offset-12 { -    margin-left: 100%; -  } -  .col-lg-offset-11 { -    margin-left: 91.66666667%; -  } -  .col-lg-offset-10 { -    margin-left: 83.33333333%; -  } -  .col-lg-offset-9 { -    margin-left: 75%; -  } -  .col-lg-offset-8 { -    margin-left: 66.66666667%; -  } -  .col-lg-offset-7 { -    margin-left: 58.33333333%; -  } -  .col-lg-offset-6 { -    margin-left: 50%; -  } -  .col-lg-offset-5 { -    margin-left: 41.66666667%; -  } -  .col-lg-offset-4 { -    margin-left: 33.33333333%; -  } -  .col-lg-offset-3 { -    margin-left: 25%; -  } -  .col-lg-offset-2 { -    margin-left: 16.66666667%; -  } -  .col-lg-offset-1 { -    margin-left: 8.33333333%; -  } -  .col-lg-offset-0 { -    margin-left: 0%; -  } -} -table { -  background-color: transparent; -} -caption { -  padding-top: 8px; -  padding-bottom: 8px; -  color: #999999; -  text-align: left; -} -th { -  text-align: left; -} -.table { -  width: 100%; -  max-width: 100%; -  margin-bottom: 21px; -} -.table > thead > tr > th, -.table > tbody > tr > th, -.table > tfoot > tr > th, -.table > thead > tr > td, -.table > tbody > tr > td, -.table > tfoot > tr > td { -  padding: 8px; -  line-height: 1.42857143; -  vertical-align: top; -  border-top: 1px solid #dddddd; -} -.table > thead > tr > th { -  vertical-align: bottom; -  border-bottom: 2px solid #dddddd; -} -.table > caption + thead > tr:first-child > th, -.table > colgroup + thead > tr:first-child > th, -.table > thead:first-child > tr:first-child > th, -.table > caption + thead > tr:first-child > td, -.table > colgroup + thead > tr:first-child > td, -.table > thead:first-child > tr:first-child > td { -  border-top: 0; -} -.table > tbody + tbody { -  border-top: 2px solid #dddddd; -} -.table .table { -  background-color: #ffffff; -} -.table-condensed > thead > tr > th, -.table-condensed > tbody > tr > th, -.table-condensed > tfoot > tr > th, -.table-condensed > thead > tr > td, -.table-condensed > tbody > tr > td, -.table-condensed > tfoot > tr > td { -  padding: 5px; -} -.table-bordered { -  border: 1px solid #dddddd; -} -.table-bordered > thead > tr > th, -.table-bordered > tbody > tr > th, -.table-bordered > tfoot > tr > th, -.table-bordered > thead > tr > td, -.table-bordered > tbody > tr > td, -.table-bordered > tfoot > tr > td { -  border: 1px solid #dddddd; -} -.table-bordered > thead > tr > th, -.table-bordered > thead > tr > td { -  border-bottom-width: 2px; -} -.table-striped > tbody > tr:nth-of-type(odd) { -  background-color: #f9f9f9; -} -.table-hover > tbody > tr:hover { -  background-color: #f5f5f5; -} -table col[class*="col-"] { -  position: static; -  float: none; -  display: table-column; -} -table td[class*="col-"], -table th[class*="col-"] { -  position: static; -  float: none; -  display: table-cell; -} -.table > thead > tr > td.active, -.table > tbody > tr > td.active, -.table > tfoot > tr > td.active, -.table > thead > tr > th.active, -.table > tbody > tr > th.active, -.table > tfoot > tr > th.active, -.table > thead > tr.active > td, -.table > tbody > tr.active > td, -.table > tfoot > tr.active > td, -.table > thead > tr.active > th, -.table > tbody > tr.active > th, -.table > tfoot > tr.active > th { -  background-color: #f5f5f5; -} -.table-hover > tbody > tr > td.active:hover, -.table-hover > tbody > tr > th.active:hover, -.table-hover > tbody > tr.active:hover > td, -.table-hover > tbody > tr:hover > .active, -.table-hover > tbody > tr.active:hover > th { -  background-color: #e8e8e8; -} -.table > thead > tr > td.success, -.table > tbody > tr > td.success, -.table > tfoot > tr > td.success, -.table > thead > tr > th.success, -.table > tbody > tr > th.success, -.table > tfoot > tr > th.success, -.table > thead > tr.success > td, -.table > tbody > tr.success > td, -.table > tfoot > tr.success > td, -.table > thead > tr.success > th, -.table > tbody > tr.success > th, -.table > tfoot > tr.success > th { -  background-color: #3fb618; -} -.table-hover > tbody > tr > td.success:hover, -.table-hover > tbody > tr > th.success:hover, -.table-hover > tbody > tr.success:hover > td, -.table-hover > tbody > tr:hover > .success, -.table-hover > tbody > tr.success:hover > th { -  background-color: #379f15; -} -.table > thead > tr > td.info, -.table > tbody > tr > td.info, -.table > tfoot > tr > td.info, -.table > thead > tr > th.info, -.table > tbody > tr > th.info, -.table > tfoot > tr > th.info, -.table > thead > tr.info > td, -.table > tbody > tr.info > td, -.table > tfoot > tr.info > td, -.table > thead > tr.info > th, -.table > tbody > tr.info > th, -.table > tfoot > tr.info > th { -  background-color: #9954bb; -} -.table-hover > tbody > tr > td.info:hover, -.table-hover > tbody > tr > th.info:hover, -.table-hover > tbody > tr.info:hover > td, -.table-hover > tbody > tr:hover > .info, -.table-hover > tbody > tr.info:hover > th { -  background-color: #8d46b0; -} -.table > thead > tr > td.warning, -.table > tbody > tr > td.warning, -.table > tfoot > tr > td.warning, -.table > thead > tr > th.warning, -.table > tbody > tr > th.warning, -.table > tfoot > tr > th.warning, -.table > thead > tr.warning > td, -.table > tbody > tr.warning > td, -.table > tfoot > tr.warning > td, -.table > thead > tr.warning > th, -.table > tbody > tr.warning > th, -.table > tfoot > tr.warning > th { -  background-color: #ff7518; -} -.table-hover > tbody > tr > td.warning:hover, -.table-hover > tbody > tr > th.warning:hover, -.table-hover > tbody > tr.warning:hover > td, -.table-hover > tbody > tr:hover > .warning, -.table-hover > tbody > tr.warning:hover > th { -  background-color: #fe6600; -} -.table > thead > tr > td.danger, -.table > tbody > tr > td.danger, -.table > tfoot > tr > td.danger, -.table > thead > tr > th.danger, -.table > tbody > tr > th.danger, -.table > tfoot > tr > th.danger, -.table > thead > tr.danger > td, -.table > tbody > tr.danger > td, -.table > tfoot > tr.danger > td, -.table > thead > tr.danger > th, -.table > tbody > tr.danger > th, -.table > tfoot > tr.danger > th { -  background-color: #ff0039; -} -.table-hover > tbody > tr > td.danger:hover, -.table-hover > tbody > tr > th.danger:hover, -.table-hover > tbody > tr.danger:hover > td, -.table-hover > tbody > tr:hover > .danger, -.table-hover > tbody > tr.danger:hover > th { -  background-color: #e60033; -} -.table-responsive { -  overflow-x: auto; -  min-height: 0.01%; -} -@media screen and (max-width: 767px) { -  .table-responsive { -    width: 100%; -    margin-bottom: 15.75px; -    overflow-y: hidden; -    -ms-overflow-style: -ms-autohiding-scrollbar; -    border: 1px solid #dddddd; -  } -  .table-responsive > .table { -    margin-bottom: 0; -  } -  .table-responsive > .table > thead > tr > th, -  .table-responsive > .table > tbody > tr > th, -  .table-responsive > .table > tfoot > tr > th, -  .table-responsive > .table > thead > tr > td, -  .table-responsive > .table > tbody > tr > td, -  .table-responsive > .table > tfoot > tr > td { -    white-space: nowrap; -  } -  .table-responsive > .table-bordered { -    border: 0; -  } -  .table-responsive > .table-bordered > thead > tr > th:first-child, -  .table-responsive > .table-bordered > tbody > tr > th:first-child, -  .table-responsive > .table-bordered > tfoot > tr > th:first-child, -  .table-responsive > .table-bordered > thead > tr > td:first-child, -  .table-responsive > .table-bordered > tbody > tr > td:first-child, -  .table-responsive > .table-bordered > tfoot > tr > td:first-child { -    border-left: 0; -  } -  .table-responsive > .table-bordered > thead > tr > th:last-child, -  .table-responsive > .table-bordered > tbody > tr > th:last-child, -  .table-responsive > .table-bordered > tfoot > tr > th:last-child, -  .table-responsive > .table-bordered > thead > tr > td:last-child, -  .table-responsive > .table-bordered > tbody > tr > td:last-child, -  .table-responsive > .table-bordered > tfoot > tr > td:last-child { -    border-right: 0; -  } -  .table-responsive > .table-bordered > tbody > tr:last-child > th, -  .table-responsive > .table-bordered > tfoot > tr:last-child > th, -  .table-responsive > .table-bordered > tbody > tr:last-child > td, -  .table-responsive > .table-bordered > tfoot > tr:last-child > td { -    border-bottom: 0; -  } -} -fieldset { -  padding: 0; -  margin: 0; -  border: 0; -  min-width: 0; -} -legend { -  display: block; -  width: 100%; -  padding: 0; -  margin-bottom: 21px; -  font-size: 22.5px; -  line-height: inherit; -  color: #333333; -  border: 0; -  border-bottom: 1px solid #e5e5e5; -} -label { -  display: inline-block; -  max-width: 100%; -  margin-bottom: 5px; -  font-weight: bold; -} -input[type="search"] { -  -webkit-box-sizing: border-box; -  -moz-box-sizing: border-box; -  box-sizing: border-box; -} -input[type="radio"], -input[type="checkbox"] { -  margin: 4px 0 0; -  margin-top: 1px \9; -  line-height: normal; -} -input[type="file"] { -  display: block; -} -input[type="range"] { -  display: block; -  width: 100%; -} -select[multiple], -select[size] { -  height: auto; -} -input[type="file"]:focus, -input[type="radio"]:focus, -input[type="checkbox"]:focus { -  outline: thin dotted; -  outline: 5px auto -webkit-focus-ring-color; -  outline-offset: -2px; -} -output { -  display: block; -  padding-top: 11px; -  font-size: 15px; -  line-height: 1.42857143; -  color: #333333; -} -.form-control { -  display: block; -  width: 100%; -  height: 43px; -  padding: 10px 18px; -  font-size: 15px; -  line-height: 1.42857143; -  color: #333333; -  background-color: #ffffff; -  background-image: none; -  border: 1px solid #cccccc; -  border-radius: 0; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -  -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; -  -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; -  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s; -} -.form-control:focus { -  border-color: #66afe9; -  outline: 0; -  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6); -  box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6); -} -.form-control::-moz-placeholder { -  color: #999999; -  opacity: 1; -} -.form-control:-ms-input-placeholder { -  color: #999999; -} -.form-control::-webkit-input-placeholder { -  color: #999999; -} -.form-control[disabled], -.form-control[readonly], -fieldset[disabled] .form-control { -  background-color: #e6e6e6; -  opacity: 1; -} -.form-control[disabled], -fieldset[disabled] .form-control { -  cursor: not-allowed; -} -textarea.form-control { -  height: auto; -} -input[type="search"] { -  -webkit-appearance: none; -} -@media screen and (-webkit-min-device-pixel-ratio: 0) { -  input[type="date"], -  input[type="time"], -  input[type="datetime-local"], -  input[type="month"] { -    line-height: 43px; -  } -  input[type="date"].input-sm, -  input[type="time"].input-sm, -  input[type="datetime-local"].input-sm, -  input[type="month"].input-sm, -  .input-group-sm input[type="date"], -  .input-group-sm input[type="time"], -  .input-group-sm input[type="datetime-local"], -  .input-group-sm input[type="month"] { -    line-height: 31px; -  } -  input[type="date"].input-lg, -  input[type="time"].input-lg, -  input[type="datetime-local"].input-lg, -  input[type="month"].input-lg, -  .input-group-lg input[type="date"], -  .input-group-lg input[type="time"], -  .input-group-lg input[type="datetime-local"], -  .input-group-lg input[type="month"] { -    line-height: 64px; -  } -} -.form-group { -  margin-bottom: 15px; -} -.radio, -.checkbox { -  position: relative; -  display: block; -  margin-top: 10px; -  margin-bottom: 10px; -} -.radio label, -.checkbox label { -  min-height: 21px; -  padding-left: 20px; -  margin-bottom: 0; -  font-weight: normal; -  cursor: pointer; -} -.radio input[type="radio"], -.radio-inline input[type="radio"], -.checkbox input[type="checkbox"], -.checkbox-inline input[type="checkbox"] { -  position: absolute; -  margin-left: -20px; -  margin-top: 4px \9; -} -.radio + .radio, -.checkbox + .checkbox { -  margin-top: -5px; -} -.radio-inline, -.checkbox-inline { -  position: relative; -  display: inline-block; -  padding-left: 20px; -  margin-bottom: 0; -  vertical-align: middle; -  font-weight: normal; -  cursor: pointer; -} -.radio-inline + .radio-inline, -.checkbox-inline + .checkbox-inline { -  margin-top: 0; -  margin-left: 10px; -} -input[type="radio"][disabled], -input[type="checkbox"][disabled], -input[type="radio"].disabled, -input[type="checkbox"].disabled, -fieldset[disabled] input[type="radio"], -fieldset[disabled] input[type="checkbox"] { -  cursor: not-allowed; -} -.radio-inline.disabled, -.checkbox-inline.disabled, -fieldset[disabled] .radio-inline, -fieldset[disabled] .checkbox-inline { -  cursor: not-allowed; -} -.radio.disabled label, -.checkbox.disabled label, -fieldset[disabled] .radio label, -fieldset[disabled] .checkbox label { -  cursor: not-allowed; -} -.form-control-static { -  padding-top: 11px; -  padding-bottom: 11px; -  margin-bottom: 0; -  min-height: 36px; -} -.form-control-static.input-lg, -.form-control-static.input-sm { -  padding-left: 0; -  padding-right: 0; -} -.input-sm { -  height: 31px; -  padding: 5px 10px; -  font-size: 13px; -  line-height: 1.5; -  border-radius: 0; -} -select.input-sm { -  height: 31px; -  line-height: 31px; -} -textarea.input-sm, -select[multiple].input-sm { -  height: auto; -} -.form-group-sm .form-control { -  height: 31px; -  padding: 5px 10px; -  font-size: 13px; -  line-height: 1.5; -  border-radius: 0; -} -select.form-group-sm .form-control { -  height: 31px; -  line-height: 31px; -} -textarea.form-group-sm .form-control, -select[multiple].form-group-sm .form-control { -  height: auto; -} -.form-group-sm .form-control-static { -  height: 31px; -  padding: 5px 10px; -  font-size: 13px; -  line-height: 1.5; -  min-height: 34px; -} -.input-lg { -  height: 64px; -  padding: 18px 30px; -  font-size: 19px; -  line-height: 1.3333333; -  border-radius: 0; -} -select.input-lg { -  height: 64px; -  line-height: 64px; -} -textarea.input-lg, -select[multiple].input-lg { -  height: auto; -} -.form-group-lg .form-control { -  height: 64px; -  padding: 18px 30px; -  font-size: 19px; -  line-height: 1.3333333; -  border-radius: 0; -} -select.form-group-lg .form-control { -  height: 64px; -  line-height: 64px; -} -textarea.form-group-lg .form-control, -select[multiple].form-group-lg .form-control { -  height: auto; -} -.form-group-lg .form-control-static { -  height: 64px; -  padding: 18px 30px; -  font-size: 19px; -  line-height: 1.3333333; -  min-height: 40px; -} -.has-feedback { -  position: relative; -} -.has-feedback .form-control { -  padding-right: 53.75px; -} -.form-control-feedback { -  position: absolute; -  top: 0; -  right: 0; -  z-index: 2; -  display: block; -  width: 43px; -  height: 43px; -  line-height: 43px; -  text-align: center; -  pointer-events: none; -} -.input-lg + .form-control-feedback { -  width: 64px; -  height: 64px; -  line-height: 64px; -} -.input-sm + .form-control-feedback { -  width: 31px; -  height: 31px; -  line-height: 31px; -} -.has-success .help-block, -.has-success .control-label, -.has-success .radio, -.has-success .checkbox, -.has-success .radio-inline, -.has-success .checkbox-inline, -.has-success.radio label, -.has-success.checkbox label, -.has-success.radio-inline label, -.has-success.checkbox-inline label { -  color: #ffffff; -} -.has-success .form-control { -  border-color: #ffffff; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -} -.has-success .form-control:focus { -  border-color: #e6e6e6; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -} -.has-success .input-group-addon { -  color: #ffffff; -  border-color: #ffffff; -  background-color: #3fb618; -} -.has-success .form-control-feedback { -  color: #ffffff; -} -.has-warning .help-block, -.has-warning .control-label, -.has-warning .radio, -.has-warning .checkbox, -.has-warning .radio-inline, -.has-warning .checkbox-inline, -.has-warning.radio label, -.has-warning.checkbox label, -.has-warning.radio-inline label, -.has-warning.checkbox-inline label { -  color: #ffffff; -} -.has-warning .form-control { -  border-color: #ffffff; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -} -.has-warning .form-control:focus { -  border-color: #e6e6e6; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -} -.has-warning .input-group-addon { -  color: #ffffff; -  border-color: #ffffff; -  background-color: #ff7518; -} -.has-warning .form-control-feedback { -  color: #ffffff; -} -.has-error .help-block, -.has-error .control-label, -.has-error .radio, -.has-error .checkbox, -.has-error .radio-inline, -.has-error .checkbox-inline, -.has-error.radio label, -.has-error.checkbox label, -.has-error.radio-inline label, -.has-error.checkbox-inline label { -  color: #ffffff; -} -.has-error .form-control { -  border-color: #ffffff; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075); -} -.has-error .form-control:focus { -  border-color: #e6e6e6; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffffff; -} -.has-error .input-group-addon { -  color: #ffffff; -  border-color: #ffffff; -  background-color: #ff0039; -} -.has-error .form-control-feedback { -  color: #ffffff; -} -.has-feedback label ~ .form-control-feedback { -  top: 26px; -} -.has-feedback label.sr-only ~ .form-control-feedback { -  top: 0; -} -.help-block { -  display: block; -  margin-top: 5px; -  margin-bottom: 10px; -  color: #737373; -} -@media (min-width: 768px) { -  .form-inline .form-group { -    display: inline-block; -    margin-bottom: 0; -    vertical-align: middle; -  } -  .form-inline .form-control { -    display: inline-block; -    width: auto; -    vertical-align: middle; -  } -  .form-inline .form-control-static { -    display: inline-block; -  } -  .form-inline .input-group { -    display: inline-table; -    vertical-align: middle; -  } -  .form-inline .input-group .input-group-addon, -  .form-inline .input-group .input-group-btn, -  .form-inline .input-group .form-control { -    width: auto; -  } -  .form-inline .input-group > .form-control { -    width: 100%; -  } -  .form-inline .control-label { -    margin-bottom: 0; -    vertical-align: middle; -  } -  .form-inline .radio, -  .form-inline .checkbox { -    display: inline-block; -    margin-top: 0; -    margin-bottom: 0; -    vertical-align: middle; -  } -  .form-inline .radio label, -  .form-inline .checkbox label { -    padding-left: 0; -  } -  .form-inline .radio input[type="radio"], -  .form-inline .checkbox input[type="checkbox"] { -    position: relative; -    margin-left: 0; -  } -  .form-inline .has-feedback .form-control-feedback { -    top: 0; -  } -} -.form-horizontal .radio, -.form-horizontal .checkbox, -.form-horizontal .radio-inline, -.form-horizontal .checkbox-inline { -  margin-top: 0; -  margin-bottom: 0; -  padding-top: 11px; -} -.form-horizontal .radio, -.form-horizontal .checkbox { -  min-height: 32px; -} -.form-horizontal .form-group { -  margin-left: -15px; -  margin-right: -15px; -} -@media (min-width: 768px) { -  .form-horizontal .control-label { -    text-align: right; -    margin-bottom: 0; -    padding-top: 11px; -  } -} -.form-horizontal .has-feedback .form-control-feedback { -  right: 15px; -} -@media (min-width: 768px) { -  .form-horizontal .form-group-lg .control-label { -    padding-top: 24.9999994px; -  } -} -@media (min-width: 768px) { -  .form-horizontal .form-group-sm .control-label { -    padding-top: 6px; -  } -} -.btn { -  display: inline-block; -  margin-bottom: 0; -  font-weight: normal; -  text-align: center; -  vertical-align: middle; -  touch-action: manipulation; -  cursor: pointer; -  background-image: none; -  border: 1px solid transparent; -  white-space: nowrap; -  padding: 10px 18px; -  font-size: 15px; -  line-height: 1.42857143; -  border-radius: 0; -  -webkit-user-select: none; -  -moz-user-select: none; -  -ms-user-select: none; -  user-select: none; -} -.btn:focus, -.btn:active:focus, -.btn.active:focus, -.btn.focus, -.btn:active.focus, -.btn.active.focus { -  outline: thin dotted; -  outline: 5px auto -webkit-focus-ring-color; -  outline-offset: -2px; -} -.btn:hover, -.btn:focus, -.btn.focus { -  color: #ffffff; -  text-decoration: none; -} -.btn:active, -.btn.active { -  outline: 0; -  background-image: none; -  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); -  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); -} -.btn.disabled, -.btn[disabled], -fieldset[disabled] .btn { -  cursor: not-allowed; -  pointer-events: none; -  opacity: 0.65; -  filter: alpha(opacity=65); -  -webkit-box-shadow: none; -  box-shadow: none; -} -.btn-default { -  color: #ffffff; -  background-color: #222222; -  border-color: #222222; -} -.btn-default:hover, -.btn-default:focus, -.btn-default.focus, -.btn-default:active, -.btn-default.active, -.open > .dropdown-toggle.btn-default { -  color: #ffffff; -  background-color: #090909; -  border-color: #040404; -} -.btn-default:active, -.btn-default.active, -.open > .dropdown-toggle.btn-default { -  background-image: none; -} -.btn-default.disabled, -.btn-default[disabled], -fieldset[disabled] .btn-default, -.btn-default.disabled:hover, -.btn-default[disabled]:hover, -fieldset[disabled] .btn-default:hover, -.btn-default.disabled:focus, -.btn-default[disabled]:focus, -fieldset[disabled] .btn-default:focus, -.btn-default.disabled.focus, -.btn-default[disabled].focus, -fieldset[disabled] .btn-default.focus, -.btn-default.disabled:active, -.btn-default[disabled]:active, -fieldset[disabled] .btn-default:active, -.btn-default.disabled.active, -.btn-default[disabled].active, -fieldset[disabled] .btn-default.active { -  background-color: #222222; -  border-color: #222222; -} -.btn-default .badge { -  color: #222222; -  background-color: #ffffff; -} -.btn-primary { -  color: #ffffff; -  background-color: #2780e3; -  border-color: #2780e3; -} -.btn-primary:hover, -.btn-primary:focus, -.btn-primary.focus, -.btn-primary:active, -.btn-primary.active, -.open > .dropdown-toggle.btn-primary { -  color: #ffffff; -  background-color: #1967be; -  border-color: #1862b5; -} -.btn-primary:active, -.btn-primary.active, -.open > .dropdown-toggle.btn-primary { -  background-image: none; -} -.btn-primary.disabled, -.btn-primary[disabled], -fieldset[disabled] .btn-primary, -.btn-primary.disabled:hover, -.btn-primary[disabled]:hover, -fieldset[disabled] .btn-primary:hover, -.btn-primary.disabled:focus, -.btn-primary[disabled]:focus, -fieldset[disabled] .btn-primary:focus, -.btn-primary.disabled.focus, -.btn-primary[disabled].focus, -fieldset[disabled] .btn-primary.focus, -.btn-primary.disabled:active, -.btn-primary[disabled]:active, -fieldset[disabled] .btn-primary:active, -.btn-primary.disabled.active, -.btn-primary[disabled].active, -fieldset[disabled] .btn-primary.active { -  background-color: #2780e3; -  border-color: #2780e3; -} -.btn-primary .badge { -  color: #2780e3; -  background-color: #ffffff; -} -.btn-success { -  color: #ffffff; -  background-color: #3fb618; -  border-color: #3fb618; -} -.btn-success:hover, -.btn-success:focus, -.btn-success.focus, -.btn-success:active, -.btn-success.active, -.open > .dropdown-toggle.btn-success { -  color: #ffffff; -  background-color: #2f8912; -  border-color: #2c8011; -} -.btn-success:active, -.btn-success.active, -.open > .dropdown-toggle.btn-success { -  background-image: none; -} -.btn-success.disabled, -.btn-success[disabled], -fieldset[disabled] .btn-success, -.btn-success.disabled:hover, -.btn-success[disabled]:hover, -fieldset[disabled] .btn-success:hover, -.btn-success.disabled:focus, -.btn-success[disabled]:focus, -fieldset[disabled] .btn-success:focus, -.btn-success.disabled.focus, -.btn-success[disabled].focus, -fieldset[disabled] .btn-success.focus, -.btn-success.disabled:active, -.btn-success[disabled]:active, -fieldset[disabled] .btn-success:active, -.btn-success.disabled.active, -.btn-success[disabled].active, -fieldset[disabled] .btn-success.active { -  background-color: #3fb618; -  border-color: #3fb618; -} -.btn-success .badge { -  color: #3fb618; -  background-color: #ffffff; -} -.btn-info { -  color: #ffffff; -  background-color: #9954bb; -  border-color: #9954bb; -} -.btn-info:hover, -.btn-info:focus, -.btn-info.focus, -.btn-info:active, -.btn-info.active, -.open > .dropdown-toggle.btn-info { -  color: #ffffff; -  background-color: #7e3f9d; -  border-color: #783c96; -} -.btn-info:active, -.btn-info.active, -.open > .dropdown-toggle.btn-info { -  background-image: none; -} -.btn-info.disabled, -.btn-info[disabled], -fieldset[disabled] .btn-info, -.btn-info.disabled:hover, -.btn-info[disabled]:hover, -fieldset[disabled] .btn-info:hover, -.btn-info.disabled:focus, -.btn-info[disabled]:focus, -fieldset[disabled] .btn-info:focus, -.btn-info.disabled.focus, -.btn-info[disabled].focus, -fieldset[disabled] .btn-info.focus, -.btn-info.disabled:active, -.btn-info[disabled]:active, -fieldset[disabled] .btn-info:active, -.btn-info.disabled.active, -.btn-info[disabled].active, -fieldset[disabled] .btn-info.active { -  background-color: #9954bb; -  border-color: #9954bb; -} -.btn-info .badge { -  color: #9954bb; -  background-color: #ffffff; -} -.btn-warning { -  color: #ffffff; -  background-color: #ff7518; -  border-color: #ff7518; -} -.btn-warning:hover, -.btn-warning:focus, -.btn-warning.focus, -.btn-warning:active, -.btn-warning.active, -.open > .dropdown-toggle.btn-warning { -  color: #ffffff; -  background-color: #e45c00; -  border-color: #da5800; -} -.btn-warning:active, -.btn-warning.active, -.open > .dropdown-toggle.btn-warning { -  background-image: none; -} -.btn-warning.disabled, -.btn-warning[disabled], -fieldset[disabled] .btn-warning, -.btn-warning.disabled:hover, -.btn-warning[disabled]:hover, -fieldset[disabled] .btn-warning:hover, -.btn-warning.disabled:focus, -.btn-warning[disabled]:focus, -fieldset[disabled] .btn-warning:focus, -.btn-warning.disabled.focus, -.btn-warning[disabled].focus, -fieldset[disabled] .btn-warning.focus, -.btn-warning.disabled:active, -.btn-warning[disabled]:active, -fieldset[disabled] .btn-warning:active, -.btn-warning.disabled.active, -.btn-warning[disabled].active, -fieldset[disabled] .btn-warning.active { -  background-color: #ff7518; -  border-color: #ff7518; -} -.btn-warning .badge { -  color: #ff7518; -  background-color: #ffffff; -} -.btn-danger { -  color: #ffffff; -  background-color: #ff0039; -  border-color: #ff0039; -} -.btn-danger:hover, -.btn-danger:focus, -.btn-danger.focus, -.btn-danger:active, -.btn-danger.active, -.open > .dropdown-toggle.btn-danger { -  color: #ffffff; -  background-color: #cc002e; -  border-color: #c2002b; -} -.btn-danger:active, -.btn-danger.active, -.open > .dropdown-toggle.btn-danger { -  background-image: none; -} -.btn-danger.disabled, -.btn-danger[disabled], -fieldset[disabled] .btn-danger, -.btn-danger.disabled:hover, -.btn-danger[disabled]:hover, -fieldset[disabled] .btn-danger:hover, -.btn-danger.disabled:focus, -.btn-danger[disabled]:focus, -fieldset[disabled] .btn-danger:focus, -.btn-danger.disabled.focus, -.btn-danger[disabled].focus, -fieldset[disabled] .btn-danger.focus, -.btn-danger.disabled:active, -.btn-danger[disabled]:active, -fieldset[disabled] .btn-danger:active, -.btn-danger.disabled.active, -.btn-danger[disabled].active, -fieldset[disabled] .btn-danger.active { -  background-color: #ff0039; -  border-color: #ff0039; -} -.btn-danger .badge { -  color: #ff0039; -  background-color: #ffffff; -} -.btn-link { -  color: #2780e3; -  font-weight: normal; -  border-radius: 0; -} -.btn-link, -.btn-link:active, -.btn-link.active, -.btn-link[disabled], -fieldset[disabled] .btn-link { -  background-color: transparent; -  -webkit-box-shadow: none; -  box-shadow: none; -} -.btn-link, -.btn-link:hover, -.btn-link:focus, -.btn-link:active { -  border-color: transparent; -} -.btn-link:hover, -.btn-link:focus { -  color: #165ba8; -  text-decoration: underline; -  background-color: transparent; -} -.btn-link[disabled]:hover, -fieldset[disabled] .btn-link:hover, -.btn-link[disabled]:focus, -fieldset[disabled] .btn-link:focus { -  color: #999999; -  text-decoration: none; -} -.btn-lg, -.btn-group-lg > .btn { -  padding: 18px 30px; -  font-size: 19px; -  line-height: 1.3333333; -  border-radius: 0; -} -.btn-sm, -.btn-group-sm > .btn { -  padding: 5px 10px; -  font-size: 13px; -  line-height: 1.5; -  border-radius: 0; -} -.btn-xs, -.btn-group-xs > .btn { -  padding: 1px 5px; -  font-size: 13px; -  line-height: 1.5; -  border-radius: 0; -} -.btn-block { -  display: block; -  width: 100%; -} -.btn-block + .btn-block { -  margin-top: 5px; -} -input[type="submit"].btn-block, -input[type="reset"].btn-block, -input[type="button"].btn-block { -  width: 100%; -} -.fade { -  opacity: 0; -  -webkit-transition: opacity 0.15s linear; -  -o-transition: opacity 0.15s linear; -  transition: opacity 0.15s linear; -} -.fade.in { -  opacity: 1; -} -.collapse { -  display: none; -} -.collapse.in { -  display: block; -} -tr.collapse.in { -  display: table-row; -} -tbody.collapse.in { -  display: table-row-group; -} -.collapsing { -  position: relative; -  height: 0; -  overflow: hidden; -  -webkit-transition-property: height, visibility; -  transition-property: height, visibility; -  -webkit-transition-duration: 0.35s; -  transition-duration: 0.35s; -  -webkit-transition-timing-function: ease; -  transition-timing-function: ease; -} -.caret { -  display: inline-block; -  width: 0; -  height: 0; -  margin-left: 2px; -  vertical-align: middle; -  border-top: 4px dashed; -  border-right: 4px solid transparent; -  border-left: 4px solid transparent; -} -.dropup, -.dropdown { -  position: relative; -} -.dropdown-toggle:focus { -  outline: 0; -} -.dropdown-menu { -  position: absolute; -  top: 100%; -  left: 0; -  z-index: 1000; -  display: none; -  float: left; -  min-width: 160px; -  padding: 5px 0; -  margin: 2px 0 0; -  list-style: none; -  font-size: 15px; -  text-align: left; -  background-color: #ffffff; -  border: 1px solid #cccccc; -  border: 1px solid rgba(0, 0, 0, 0.15); -  border-radius: 0; -  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175); -  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175); -  background-clip: padding-box; -} -.dropdown-menu.pull-right { -  right: 0; -  left: auto; -} -.dropdown-menu .divider { -  height: 1px; -  margin: 9.5px 0; -  overflow: hidden; -  background-color: #e5e5e5; -} -.dropdown-menu > li > a { -  display: block; -  padding: 3px 20px; -  clear: both; -  font-weight: normal; -  line-height: 1.42857143; -  color: #333333; -  white-space: nowrap; -} -.dropdown-menu > li > a:hover, -.dropdown-menu > li > a:focus { -  text-decoration: none; -  color: #ffffff; -  background-color: #2780e3; -} -.dropdown-menu > .active > a, -.dropdown-menu > .active > a:hover, -.dropdown-menu > .active > a:focus { -  color: #ffffff; -  text-decoration: none; -  outline: 0; -  background-color: #2780e3; -} -.dropdown-menu > .disabled > a, -.dropdown-menu > .disabled > a:hover, -.dropdown-menu > .disabled > a:focus { -  color: #999999; -} -.dropdown-menu > .disabled > a:hover, -.dropdown-menu > .disabled > a:focus { -  text-decoration: none; -  background-color: transparent; -  background-image: none; -  filter: progid:DXImageTransform.Microsoft.gradient(enabled = false); -  cursor: not-allowed; -} -.open > .dropdown-menu { -  display: block; -} -.open > a { -  outline: 0; -} -.dropdown-menu-right { -  left: auto; -  right: 0; -} -.dropdown-menu-left { -  left: 0; -  right: auto; -} -.dropdown-header { -  display: block; -  padding: 3px 20px; -  font-size: 13px; -  line-height: 1.42857143; -  color: #999999; -  white-space: nowrap; -} -.dropdown-backdrop { -  position: fixed; -  left: 0; -  right: 0; -  bottom: 0; -  top: 0; -  z-index: 990; -} -.pull-right > .dropdown-menu { -  right: 0; -  left: auto; -} -.dropup .caret, -.navbar-fixed-bottom .dropdown .caret { -  border-top: 0; -  border-bottom: 4px solid; -  content: ""; -} -.dropup .dropdown-menu, -.navbar-fixed-bottom .dropdown .dropdown-menu { -  top: auto; -  bottom: 100%; -  margin-bottom: 2px; -} -@media (min-width: 768px) { -  .navbar-right .dropdown-menu { -    left: auto; -    right: 0; -  } -  .navbar-right .dropdown-menu-left { -    left: 0; -    right: auto; -  } -} -.btn-group, -.btn-group-vertical { -  position: relative; -  display: inline-block; -  vertical-align: middle; -} -.btn-group > .btn, -.btn-group-vertical > .btn { -  position: relative; -  float: left; -} -.btn-group > .btn:hover, -.btn-group-vertical > .btn:hover, -.btn-group > .btn:focus, -.btn-group-vertical > .btn:focus, -.btn-group > .btn:active, -.btn-group-vertical > .btn:active, -.btn-group > .btn.active, -.btn-group-vertical > .btn.active { -  z-index: 2; -} -.btn-group .btn + .btn, -.btn-group .btn + .btn-group, -.btn-group .btn-group + .btn, -.btn-group .btn-group + .btn-group { -  margin-left: -1px; -} -.btn-toolbar { -  margin-left: -5px; -} -.btn-toolbar .btn-group, -.btn-toolbar .input-group { -  float: left; -} -.btn-toolbar > .btn, -.btn-toolbar > .btn-group, -.btn-toolbar > .input-group { -  margin-left: 5px; -} -.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) { -  border-radius: 0; -} -.btn-group > .btn:first-child { -  margin-left: 0; -} -.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.btn-group > .btn:last-child:not(:first-child), -.btn-group > .dropdown-toggle:not(:first-child) { -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.btn-group > .btn-group { -  float: left; -} -.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn { -  border-radius: 0; -} -.btn-group > .btn-group:first-child:not(:last-child) > .btn:last-child, -.btn-group > .btn-group:first-child:not(:last-child) > .dropdown-toggle { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child { -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.btn-group .dropdown-toggle:active, -.btn-group.open .dropdown-toggle { -  outline: 0; -} -.btn-group > .btn + .dropdown-toggle { -  padding-left: 8px; -  padding-right: 8px; -} -.btn-group > .btn-lg + .dropdown-toggle { -  padding-left: 12px; -  padding-right: 12px; -} -.btn-group.open .dropdown-toggle { -  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); -  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); -} -.btn-group.open .dropdown-toggle.btn-link { -  -webkit-box-shadow: none; -  box-shadow: none; -} -.btn .caret { -  margin-left: 0; -} -.btn-lg .caret { -  border-width: 5px 5px 0; -  border-bottom-width: 0; -} -.dropup .btn-lg .caret { -  border-width: 0 5px 5px; -} -.btn-group-vertical > .btn, -.btn-group-vertical > .btn-group, -.btn-group-vertical > .btn-group > .btn { -  display: block; -  float: none; -  width: 100%; -  max-width: 100%; -} -.btn-group-vertical > .btn-group > .btn { -  float: none; -} -.btn-group-vertical > .btn + .btn, -.btn-group-vertical > .btn + .btn-group, -.btn-group-vertical > .btn-group + .btn, -.btn-group-vertical > .btn-group + .btn-group { -  margin-top: -1px; -  margin-left: 0; -} -.btn-group-vertical > .btn:not(:first-child):not(:last-child) { -  border-radius: 0; -} -.btn-group-vertical > .btn:first-child:not(:last-child) { -  border-top-right-radius: 0; -  border-bottom-right-radius: 0; -  border-bottom-left-radius: 0; -} -.btn-group-vertical > .btn:last-child:not(:first-child) { -  border-bottom-left-radius: 0; -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn { -  border-radius: 0; -} -.btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child, -.btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle { -  border-bottom-right-radius: 0; -  border-bottom-left-radius: 0; -} -.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child { -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.btn-group-justified { -  display: table; -  width: 100%; -  table-layout: fixed; -  border-collapse: separate; -} -.btn-group-justified > .btn, -.btn-group-justified > .btn-group { -  float: none; -  display: table-cell; -  width: 1%; -} -.btn-group-justified > .btn-group .btn { -  width: 100%; -} -.btn-group-justified > .btn-group .dropdown-menu { -  left: auto; -} -[data-toggle="buttons"] > .btn input[type="radio"], -[data-toggle="buttons"] > .btn-group > .btn input[type="radio"], -[data-toggle="buttons"] > .btn input[type="checkbox"], -[data-toggle="buttons"] > .btn-group > .btn input[type="checkbox"] { -  position: absolute; -  clip: rect(0, 0, 0, 0); -  pointer-events: none; -} -.input-group { -  position: relative; -  display: table; -  border-collapse: separate; -} -.input-group[class*="col-"] { -  float: none; -  padding-left: 0; -  padding-right: 0; -} -.input-group .form-control { -  position: relative; -  z-index: 2; -  float: left; -  width: 100%; -  margin-bottom: 0; -} -.input-group-lg > .form-control, -.input-group-lg > .input-group-addon, -.input-group-lg > .input-group-btn > .btn { -  height: 64px; -  padding: 18px 30px; -  font-size: 19px; -  line-height: 1.3333333; -  border-radius: 0; -} -select.input-group-lg > .form-control, -select.input-group-lg > .input-group-addon, -select.input-group-lg > .input-group-btn > .btn { -  height: 64px; -  line-height: 64px; -} -textarea.input-group-lg > .form-control, -textarea.input-group-lg > .input-group-addon, -textarea.input-group-lg > .input-group-btn > .btn, -select[multiple].input-group-lg > .form-control, -select[multiple].input-group-lg > .input-group-addon, -select[multiple].input-group-lg > .input-group-btn > .btn { -  height: auto; -} -.input-group-sm > .form-control, -.input-group-sm > .input-group-addon, -.input-group-sm > .input-group-btn > .btn { -  height: 31px; -  padding: 5px 10px; -  font-size: 13px; -  line-height: 1.5; -  border-radius: 0; -} -select.input-group-sm > .form-control, -select.input-group-sm > .input-group-addon, -select.input-group-sm > .input-group-btn > .btn { -  height: 31px; -  line-height: 31px; -} -textarea.input-group-sm > .form-control, -textarea.input-group-sm > .input-group-addon, -textarea.input-group-sm > .input-group-btn > .btn, -select[multiple].input-group-sm > .form-control, -select[multiple].input-group-sm > .input-group-addon, -select[multiple].input-group-sm > .input-group-btn > .btn { -  height: auto; -} -.input-group-addon, -.input-group-btn, -.input-group .form-control { -  display: table-cell; -} -.input-group-addon:not(:first-child):not(:last-child), -.input-group-btn:not(:first-child):not(:last-child), -.input-group .form-control:not(:first-child):not(:last-child) { -  border-radius: 0; -} -.input-group-addon, -.input-group-btn { -  width: 1%; -  white-space: nowrap; -  vertical-align: middle; -} -.input-group-addon { -  padding: 10px 18px; -  font-size: 15px; -  font-weight: normal; -  line-height: 1; -  color: #333333; -  text-align: center; -  background-color: #e6e6e6; -  border: 1px solid #cccccc; -  border-radius: 0; -} -.input-group-addon.input-sm { -  padding: 5px 10px; -  font-size: 13px; -  border-radius: 0; -} -.input-group-addon.input-lg { -  padding: 18px 30px; -  font-size: 19px; -  border-radius: 0; -} -.input-group-addon input[type="radio"], -.input-group-addon input[type="checkbox"] { -  margin-top: 0; -} -.input-group .form-control:first-child, -.input-group-addon:first-child, -.input-group-btn:first-child > .btn, -.input-group-btn:first-child > .btn-group > .btn, -.input-group-btn:first-child > .dropdown-toggle, -.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle), -.input-group-btn:last-child > .btn-group:not(:last-child) > .btn { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.input-group-addon:first-child { -  border-right: 0; -} -.input-group .form-control:last-child, -.input-group-addon:last-child, -.input-group-btn:last-child > .btn, -.input-group-btn:last-child > .btn-group > .btn, -.input-group-btn:last-child > .dropdown-toggle, -.input-group-btn:first-child > .btn:not(:first-child), -.input-group-btn:first-child > .btn-group:not(:first-child) > .btn { -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.input-group-addon:last-child { -  border-left: 0; -} -.input-group-btn { -  position: relative; -  font-size: 0; -  white-space: nowrap; -} -.input-group-btn > .btn { -  position: relative; -} -.input-group-btn > .btn + .btn { -  margin-left: -1px; -} -.input-group-btn > .btn:hover, -.input-group-btn > .btn:focus, -.input-group-btn > .btn:active { -  z-index: 2; -} -.input-group-btn:first-child > .btn, -.input-group-btn:first-child > .btn-group { -  margin-right: -1px; -} -.input-group-btn:last-child > .btn, -.input-group-btn:last-child > .btn-group { -  margin-left: -1px; -} -.nav { -  margin-bottom: 0; -  padding-left: 0; -  list-style: none; -} -.nav > li { -  position: relative; -  display: block; -} -.nav > li > a { -  position: relative; -  display: block; -  padding: 10px 15px; -} -.nav > li > a:hover, -.nav > li > a:focus { -  text-decoration: none; -  background-color: #e6e6e6; -} -.nav > li.disabled > a { -  color: #999999; -} -.nav > li.disabled > a:hover, -.nav > li.disabled > a:focus { -  color: #999999; -  text-decoration: none; -  background-color: transparent; -  cursor: not-allowed; -} -.nav .open > a, -.nav .open > a:hover, -.nav .open > a:focus { -  background-color: #e6e6e6; -  border-color: #2780e3; -} -.nav .nav-divider { -  height: 1px; -  margin: 9.5px 0; -  overflow: hidden; -  background-color: #e5e5e5; -} -.nav > li > a > img { -  max-width: none; -} -.nav-tabs { -  border-bottom: 1px solid #dddddd; -} -.nav-tabs > li { -  float: left; -  margin-bottom: -1px; -} -.nav-tabs > li > a { -  margin-right: 2px; -  line-height: 1.42857143; -  border: 1px solid transparent; -  border-radius: 0 0 0 0; -} -.nav-tabs > li > a:hover { -  border-color: #e6e6e6 #e6e6e6 #dddddd; -} -.nav-tabs > li.active > a, -.nav-tabs > li.active > a:hover, -.nav-tabs > li.active > a:focus { -  color: #555555; -  background-color: #ffffff; -  border: 1px solid #dddddd; -  border-bottom-color: transparent; -  cursor: default; -} -.nav-tabs.nav-justified { -  width: 100%; -  border-bottom: 0; -} -.nav-tabs.nav-justified > li { -  float: none; -} -.nav-tabs.nav-justified > li > a { -  text-align: center; -  margin-bottom: 5px; -} -.nav-tabs.nav-justified > .dropdown .dropdown-menu { -  top: auto; -  left: auto; -} -@media (min-width: 768px) { -  .nav-tabs.nav-justified > li { -    display: table-cell; -    width: 1%; -  } -  .nav-tabs.nav-justified > li > a { -    margin-bottom: 0; -  } -} -.nav-tabs.nav-justified > li > a { -  margin-right: 0; -  border-radius: 0; -} -.nav-tabs.nav-justified > .active > a, -.nav-tabs.nav-justified > .active > a:hover, -.nav-tabs.nav-justified > .active > a:focus { -  border: 1px solid #dddddd; -} -@media (min-width: 768px) { -  .nav-tabs.nav-justified > li > a { -    border-bottom: 1px solid #dddddd; -    border-radius: 0 0 0 0; -  } -  .nav-tabs.nav-justified > .active > a, -  .nav-tabs.nav-justified > .active > a:hover, -  .nav-tabs.nav-justified > .active > a:focus { -    border-bottom-color: #ffffff; -  } -} -.nav-pills > li { -  float: left; -} -.nav-pills > li > a { -  border-radius: 0; -} -.nav-pills > li + li { -  margin-left: 2px; -} -.nav-pills > li.active > a, -.nav-pills > li.active > a:hover, -.nav-pills > li.active > a:focus { -  color: #ffffff; -  background-color: #2780e3; -} -.nav-stacked > li { -  float: none; -} -.nav-stacked > li + li { -  margin-top: 2px; -  margin-left: 0; -} -.nav-justified { -  width: 100%; -} -.nav-justified > li { -  float: none; -} -.nav-justified > li > a { -  text-align: center; -  margin-bottom: 5px; -} -.nav-justified > .dropdown .dropdown-menu { -  top: auto; -  left: auto; -} -@media (min-width: 768px) { -  .nav-justified > li { -    display: table-cell; -    width: 1%; -  } -  .nav-justified > li > a { -    margin-bottom: 0; -  } -} -.nav-tabs-justified { -  border-bottom: 0; -} -.nav-tabs-justified > li > a { -  margin-right: 0; -  border-radius: 0; -} -.nav-tabs-justified > .active > a, -.nav-tabs-justified > .active > a:hover, -.nav-tabs-justified > .active > a:focus { -  border: 1px solid #dddddd; -} -@media (min-width: 768px) { -  .nav-tabs-justified > li > a { -    border-bottom: 1px solid #dddddd; -    border-radius: 0 0 0 0; -  } -  .nav-tabs-justified > .active > a, -  .nav-tabs-justified > .active > a:hover, -  .nav-tabs-justified > .active > a:focus { -    border-bottom-color: #ffffff; -  } -} -.tab-content > .tab-pane { -  display: none; -} -.tab-content > .active { -  display: block; -} -.nav-tabs .dropdown-menu { -  margin-top: -1px; -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.navbar { -  position: relative; -  min-height: 50px; -  margin-bottom: 21px; -  border: 1px solid transparent; -} -@media (min-width: 768px) { -  .navbar { -    border-radius: 0; -  } -} -@media (min-width: 768px) { -  .navbar-header { -    float: left; -  } -} -.navbar-collapse { -  overflow-x: visible; -  padding-right: 15px; -  padding-left: 15px; -  border-top: 1px solid transparent; -  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1); -  -webkit-overflow-scrolling: touch; -} -.navbar-collapse.in { -  overflow-y: auto; -} -@media (min-width: 768px) { -  .navbar-collapse { -    width: auto; -    border-top: 0; -    box-shadow: none; -  } -  .navbar-collapse.collapse { -    display: block !important; -    height: auto !important; -    padding-bottom: 0; -    overflow: visible !important; -  } -  .navbar-collapse.in { -    overflow-y: visible; -  } -  .navbar-fixed-top .navbar-collapse, -  .navbar-static-top .navbar-collapse, -  .navbar-fixed-bottom .navbar-collapse { -    padding-left: 0; -    padding-right: 0; -  } -} -.navbar-fixed-top .navbar-collapse, -.navbar-fixed-bottom .navbar-collapse { -  max-height: 340px; -} -@media (max-device-width: 480px) and (orientation: landscape) { -  .navbar-fixed-top .navbar-collapse, -  .navbar-fixed-bottom .navbar-collapse { -    max-height: 200px; -  } -} -.container > .navbar-header, -.container-fluid > .navbar-header, -.container > .navbar-collapse, -.container-fluid > .navbar-collapse { -  margin-right: -15px; -  margin-left: -15px; -} -@media (min-width: 768px) { -  .container > .navbar-header, -  .container-fluid > .navbar-header, -  .container > .navbar-collapse, -  .container-fluid > .navbar-collapse { -    margin-right: 0; -    margin-left: 0; -  } -} -.navbar-static-top { -  z-index: 1000; -  border-width: 0 0 1px; -} -@media (min-width: 768px) { -  .navbar-static-top { -    border-radius: 0; -  } -} -.navbar-fixed-top, -.navbar-fixed-bottom { -  position: fixed; -  right: 0; -  left: 0; -  z-index: 1030; -} -@media (min-width: 768px) { -  .navbar-fixed-top, -  .navbar-fixed-bottom { -    border-radius: 0; -  } -} -.navbar-fixed-top { -  top: 0; -  border-width: 0 0 1px; -} -.navbar-fixed-bottom { -  bottom: 0; -  margin-bottom: 0; -  border-width: 1px 0 0; -} -.navbar-brand { -  float: left; -  padding: 14.5px 15px; -  font-size: 19px; -  line-height: 21px; -  height: 50px; -} -.navbar-brand:hover, -.navbar-brand:focus { -  text-decoration: none; -} -.navbar-brand > img { -  display: block; -} -@media (min-width: 768px) { -  .navbar > .container .navbar-brand, -  .navbar > .container-fluid .navbar-brand { -    margin-left: -15px; -  } -} -.navbar-toggle { -  position: relative; -  float: right; -  margin-right: 15px; -  padding: 9px 10px; -  margin-top: 8px; -  margin-bottom: 8px; -  background-color: transparent; -  background-image: none; -  border: 1px solid transparent; -  border-radius: 0; -} -.navbar-toggle:focus { -  outline: 0; -} -.navbar-toggle .icon-bar { -  display: block; -  width: 22px; -  height: 2px; -  border-radius: 1px; -} -.navbar-toggle .icon-bar + .icon-bar { -  margin-top: 4px; -} -@media (min-width: 768px) { -  .navbar-toggle { -    display: none; -  } -} -.navbar-nav { -  margin: 7.25px -15px; -} -.navbar-nav > li > a { -  padding-top: 10px; -  padding-bottom: 10px; -  line-height: 21px; -} -@media (max-width: 767px) { -  .navbar-nav .open .dropdown-menu { -    position: static; -    float: none; -    width: auto; -    margin-top: 0; -    background-color: transparent; -    border: 0; -    box-shadow: none; -  } -  .navbar-nav .open .dropdown-menu > li > a, -  .navbar-nav .open .dropdown-menu .dropdown-header { -    padding: 5px 15px 5px 25px; -  } -  .navbar-nav .open .dropdown-menu > li > a { -    line-height: 21px; -  } -  .navbar-nav .open .dropdown-menu > li > a:hover, -  .navbar-nav .open .dropdown-menu > li > a:focus { -    background-image: none; -  } -} -@media (min-width: 768px) { -  .navbar-nav { -    float: left; -    margin: 0; -  } -  .navbar-nav > li { -    float: left; -  } -  .navbar-nav > li > a { -    padding-top: 14.5px; -    padding-bottom: 14.5px; -  } -} -.navbar-form { -  margin-left: -15px; -  margin-right: -15px; -  padding: 10px 15px; -  border-top: 1px solid transparent; -  border-bottom: 1px solid transparent; -  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1); -  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1); -  margin-top: 3.5px; -  margin-bottom: 3.5px; -} -@media (min-width: 768px) { -  .navbar-form .form-group { -    display: inline-block; -    margin-bottom: 0; -    vertical-align: middle; -  } -  .navbar-form .form-control { -    display: inline-block; -    width: auto; -    vertical-align: middle; -  } -  .navbar-form .form-control-static { -    display: inline-block; -  } -  .navbar-form .input-group { -    display: inline-table; -    vertical-align: middle; -  } -  .navbar-form .input-group .input-group-addon, -  .navbar-form .input-group .input-group-btn, -  .navbar-form .input-group .form-control { -    width: auto; -  } -  .navbar-form .input-group > .form-control { -    width: 100%; -  } -  .navbar-form .control-label { -    margin-bottom: 0; -    vertical-align: middle; -  } -  .navbar-form .radio, -  .navbar-form .checkbox { -    display: inline-block; -    margin-top: 0; -    margin-bottom: 0; -    vertical-align: middle; -  } -  .navbar-form .radio label, -  .navbar-form .checkbox label { -    padding-left: 0; -  } -  .navbar-form .radio input[type="radio"], -  .navbar-form .checkbox input[type="checkbox"] { -    position: relative; -    margin-left: 0; -  } -  .navbar-form .has-feedback .form-control-feedback { -    top: 0; -  } -} -@media (max-width: 767px) { -  .navbar-form .form-group { -    margin-bottom: 5px; -  } -  .navbar-form .form-group:last-child { -    margin-bottom: 0; -  } -} -@media (min-width: 768px) { -  .navbar-form { -    width: auto; -    border: 0; -    margin-left: 0; -    margin-right: 0; -    padding-top: 0; -    padding-bottom: 0; -    -webkit-box-shadow: none; -    box-shadow: none; -  } -} -.navbar-nav > li > .dropdown-menu { -  margin-top: 0; -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu { -  margin-bottom: 0; -  border-top-right-radius: 0; -  border-top-left-radius: 0; -  border-bottom-right-radius: 0; -  border-bottom-left-radius: 0; -} -.navbar-btn { -  margin-top: 3.5px; -  margin-bottom: 3.5px; -} -.navbar-btn.btn-sm { -  margin-top: 9.5px; -  margin-bottom: 9.5px; -} -.navbar-btn.btn-xs { -  margin-top: 14px; -  margin-bottom: 14px; -} -.navbar-text { -  margin-top: 14.5px; -  margin-bottom: 14.5px; -} -@media (min-width: 768px) { -  .navbar-text { -    float: left; -    margin-left: 15px; -    margin-right: 15px; -  } -} -@media (min-width: 768px) { -  .navbar-left { -    float: left !important; -  } -  .navbar-right { -    float: right !important; -    margin-right: -15px; -  } -  .navbar-right ~ .navbar-right { -    margin-right: 0; -  } -} -.navbar-default { -  background-color: #222222; -  border-color: #121212; -} -.navbar-default .navbar-brand { -  color: #ffffff; -} -.navbar-default .navbar-brand:hover, -.navbar-default .navbar-brand:focus { -  color: #ffffff; -  background-color: none; -} -.navbar-default .navbar-text { -  color: #ffffff; -} -.navbar-default .navbar-nav > li > a { -  color: #ffffff; -} -.navbar-default .navbar-nav > li > a:hover, -.navbar-default .navbar-nav > li > a:focus { -  color: #ffffff; -  background-color: #090909; -} -.navbar-default .navbar-nav > .active > a, -.navbar-default .navbar-nav > .active > a:hover, -.navbar-default .navbar-nav > .active > a:focus { -  color: #ffffff; -  background-color: #090909; -} -.navbar-default .navbar-nav > .disabled > a, -.navbar-default .navbar-nav > .disabled > a:hover, -.navbar-default .navbar-nav > .disabled > a:focus { -  color: #cccccc; -  background-color: transparent; -} -.navbar-default .navbar-toggle { -  border-color: transparent; -} -.navbar-default .navbar-toggle:hover, -.navbar-default .navbar-toggle:focus { -  background-color: #090909; -} -.navbar-default .navbar-toggle .icon-bar { -  background-color: #ffffff; -} -.navbar-default .navbar-collapse, -.navbar-default .navbar-form { -  border-color: #121212; -} -.navbar-default .navbar-nav > .open > a, -.navbar-default .navbar-nav > .open > a:hover, -.navbar-default .navbar-nav > .open > a:focus { -  background-color: #090909; -  color: #ffffff; -} -@media (max-width: 767px) { -  .navbar-default .navbar-nav .open .dropdown-menu > li > a { -    color: #ffffff; -  } -  .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover, -  .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus { -    color: #ffffff; -    background-color: #090909; -  } -  .navbar-default .navbar-nav .open .dropdown-menu > .active > a, -  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover, -  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus { -    color: #ffffff; -    background-color: #090909; -  } -  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a, -  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover, -  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus { -    color: #cccccc; -    background-color: transparent; -  } -} -.navbar-default .navbar-link { -  color: #ffffff; -} -.navbar-default .navbar-link:hover { -  color: #ffffff; -} -.navbar-default .btn-link { -  color: #ffffff; -} -.navbar-default .btn-link:hover, -.navbar-default .btn-link:focus { -  color: #ffffff; -} -.navbar-default .btn-link[disabled]:hover, -fieldset[disabled] .navbar-default .btn-link:hover, -.navbar-default .btn-link[disabled]:focus, -fieldset[disabled] .navbar-default .btn-link:focus { -  color: #cccccc; -} -.navbar-inverse { -  background-color: #2780e3; -  border-color: #1967be; -} -.navbar-inverse .navbar-brand { -  color: #ffffff; -} -.navbar-inverse .navbar-brand:hover, -.navbar-inverse .navbar-brand:focus { -  color: #ffffff; -  background-color: none; -} -.navbar-inverse .navbar-text { -  color: #ffffff; -} -.navbar-inverse .navbar-nav > li > a { -  color: #ffffff; -} -.navbar-inverse .navbar-nav > li > a:hover, -.navbar-inverse .navbar-nav > li > a:focus { -  color: #ffffff; -  background-color: #1967be; -} -.navbar-inverse .navbar-nav > .active > a, -.navbar-inverse .navbar-nav > .active > a:hover, -.navbar-inverse .navbar-nav > .active > a:focus { -  color: #ffffff; -  background-color: #1967be; -} -.navbar-inverse .navbar-nav > .disabled > a, -.navbar-inverse .navbar-nav > .disabled > a:hover, -.navbar-inverse .navbar-nav > .disabled > a:focus { -  color: #ffffff; -  background-color: transparent; -} -.navbar-inverse .navbar-toggle { -  border-color: transparent; -} -.navbar-inverse .navbar-toggle:hover, -.navbar-inverse .navbar-toggle:focus { -  background-color: #1967be; -} -.navbar-inverse .navbar-toggle .icon-bar { -  background-color: #ffffff; -} -.navbar-inverse .navbar-collapse, -.navbar-inverse .navbar-form { -  border-color: #1a6ecc; -} -.navbar-inverse .navbar-nav > .open > a, -.navbar-inverse .navbar-nav > .open > a:hover, -.navbar-inverse .navbar-nav > .open > a:focus { -  background-color: #1967be; -  color: #ffffff; -} -@media (max-width: 767px) { -  .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header { -    border-color: #1967be; -  } -  .navbar-inverse .navbar-nav .open .dropdown-menu .divider { -    background-color: #1967be; -  } -  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a { -    color: #ffffff; -  } -  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover, -  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus { -    color: #ffffff; -    background-color: #1967be; -  } -  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a, -  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover, -  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus { -    color: #ffffff; -    background-color: #1967be; -  } -  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a, -  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover, -  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus { -    color: #ffffff; -    background-color: transparent; -  } -} -.navbar-inverse .navbar-link { -  color: #ffffff; -} -.navbar-inverse .navbar-link:hover { -  color: #ffffff; -} -.navbar-inverse .btn-link { -  color: #ffffff; -} -.navbar-inverse .btn-link:hover, -.navbar-inverse .btn-link:focus { -  color: #ffffff; -} -.navbar-inverse .btn-link[disabled]:hover, -fieldset[disabled] .navbar-inverse .btn-link:hover, -.navbar-inverse .btn-link[disabled]:focus, -fieldset[disabled] .navbar-inverse .btn-link:focus { -  color: #ffffff; -} -.breadcrumb { -  padding: 8px 15px; -  margin-bottom: 21px; -  list-style: none; -  background-color: #f5f5f5; -  border-radius: 0; -} -.breadcrumb > li { -  display: inline-block; -} -.breadcrumb > li + li:before { -  content: "/\00a0"; -  padding: 0 5px; -  color: #cccccc; -} -.breadcrumb > .active { -  color: #999999; -} -.pagination { -  display: inline-block; -  padding-left: 0; -  margin: 21px 0; -  border-radius: 0; -} -.pagination > li { -  display: inline; -} -.pagination > li > a, -.pagination > li > span { -  position: relative; -  float: left; -  padding: 10px 18px; -  line-height: 1.42857143; -  text-decoration: none; -  color: #2780e3; -  background-color: #ffffff; -  border: 1px solid #dddddd; -  margin-left: -1px; -} -.pagination > li:first-child > a, -.pagination > li:first-child > span { -  margin-left: 0; -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.pagination > li:last-child > a, -.pagination > li:last-child > span { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.pagination > li > a:hover, -.pagination > li > span:hover, -.pagination > li > a:focus, -.pagination > li > span:focus { -  color: #165ba8; -  background-color: #e6e6e6; -  border-color: #dddddd; -} -.pagination > .active > a, -.pagination > .active > span, -.pagination > .active > a:hover, -.pagination > .active > span:hover, -.pagination > .active > a:focus, -.pagination > .active > span:focus { -  z-index: 2; -  color: #999999; -  background-color: #f5f5f5; -  border-color: #dddddd; -  cursor: default; -} -.pagination > .disabled > span, -.pagination > .disabled > span:hover, -.pagination > .disabled > span:focus, -.pagination > .disabled > a, -.pagination > .disabled > a:hover, -.pagination > .disabled > a:focus { -  color: #999999; -  background-color: #ffffff; -  border-color: #dddddd; -  cursor: not-allowed; -} -.pagination-lg > li > a, -.pagination-lg > li > span { -  padding: 18px 30px; -  font-size: 19px; -} -.pagination-lg > li:first-child > a, -.pagination-lg > li:first-child > span { -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.pagination-lg > li:last-child > a, -.pagination-lg > li:last-child > span { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.pagination-sm > li > a, -.pagination-sm > li > span { -  padding: 5px 10px; -  font-size: 13px; -} -.pagination-sm > li:first-child > a, -.pagination-sm > li:first-child > span { -  border-bottom-left-radius: 0; -  border-top-left-radius: 0; -} -.pagination-sm > li:last-child > a, -.pagination-sm > li:last-child > span { -  border-bottom-right-radius: 0; -  border-top-right-radius: 0; -} -.pager { -  padding-left: 0; -  margin: 21px 0; -  list-style: none; -  text-align: center; -} -.pager li { -  display: inline; -} -.pager li > a, -.pager li > span { -  display: inline-block; -  padding: 5px 14px; -  background-color: #ffffff; -  border: 1px solid #dddddd; -  border-radius: 0; -} -.pager li > a:hover, -.pager li > a:focus { -  text-decoration: none; -  background-color: #e6e6e6; -} -.pager .next > a, -.pager .next > span { -  float: right; -} -.pager .previous > a, -.pager .previous > span { -  float: left; -} -.pager .disabled > a, -.pager .disabled > a:hover, -.pager .disabled > a:focus, -.pager .disabled > span { -  color: #999999; -  background-color: #ffffff; -  cursor: not-allowed; -} -.label { -  display: inline; -  padding: .2em .6em .3em; -  font-size: 75%; -  font-weight: bold; -  line-height: 1; -  color: #ffffff; -  text-align: center; -  white-space: nowrap; -  vertical-align: baseline; -  border-radius: .25em; -} -a.label:hover, -a.label:focus { -  color: #ffffff; -  text-decoration: none; -  cursor: pointer; -} -.label:empty { -  display: none; -} -.btn .label { -  position: relative; -  top: -1px; -} -.label-default { -  background-color: #222222; -} -.label-default[href]:hover, -.label-default[href]:focus { -  background-color: #090909; -} -.label-primary { -  background-color: #2780e3; -} -.label-primary[href]:hover, -.label-primary[href]:focus { -  background-color: #1967be; -} -.label-success { -  background-color: #3fb618; -} -.label-success[href]:hover, -.label-success[href]:focus { -  background-color: #2f8912; -} -.label-info { -  background-color: #9954bb; -} -.label-info[href]:hover, -.label-info[href]:focus { -  background-color: #7e3f9d; -} -.label-warning { -  background-color: #ff7518; -} -.label-warning[href]:hover, -.label-warning[href]:focus { -  background-color: #e45c00; -} -.label-danger { -  background-color: #ff0039; -} -.label-danger[href]:hover, -.label-danger[href]:focus { -  background-color: #cc002e; -} -.badge { -  display: inline-block; -  min-width: 10px; -  padding: 3px 7px; -  font-size: 13px; -  font-weight: bold; -  color: #ffffff; -  line-height: 1; -  vertical-align: baseline; -  white-space: nowrap; -  text-align: center; -  background-color: #2780e3; -  border-radius: 10px; -} -.badge:empty { -  display: none; -} -.btn .badge { -  position: relative; -  top: -1px; -} -.btn-xs .badge, -.btn-group-xs > .btn .badge { -  top: 0; -  padding: 1px 5px; -} -a.badge:hover, -a.badge:focus { -  color: #ffffff; -  text-decoration: none; -  cursor: pointer; -} -.list-group-item.active > .badge, -.nav-pills > .active > a > .badge { -  color: #2780e3; -  background-color: #ffffff; -} -.list-group-item > .badge { -  float: right; -} -.list-group-item > .badge + .badge { -  margin-right: 5px; -} -.nav-pills > li > a > .badge { -  margin-left: 3px; -} -.jumbotron { -  padding: 30px 15px; -  margin-bottom: 30px; -  color: inherit; -  background-color: #e6e6e6; -} -.jumbotron h1, -.jumbotron .h1 { -  color: inherit; -} -.jumbotron p { -  margin-bottom: 15px; -  font-size: 23px; -  font-weight: 200; -} -.jumbotron > hr { -  border-top-color: #cccccc; -} -.container .jumbotron, -.container-fluid .jumbotron { -  border-radius: 0; -} -.jumbotron .container { -  max-width: 100%; -} -@media screen and (min-width: 768px) { -  .jumbotron { -    padding: 48px 0; -  } -  .container .jumbotron, -  .container-fluid .jumbotron { -    padding-left: 60px; -    padding-right: 60px; -  } -  .jumbotron h1, -  .jumbotron .h1 { -    font-size: 67.5px; -  } -} -.thumbnail { -  display: block; -  padding: 4px; -  margin-bottom: 21px; -  line-height: 1.42857143; -  background-color: #ffffff; -  border: 1px solid #dddddd; -  border-radius: 0; -  -webkit-transition: border 0.2s ease-in-out; -  -o-transition: border 0.2s ease-in-out; -  transition: border 0.2s ease-in-out; -} -.thumbnail > img, -.thumbnail a > img { -  margin-left: auto; -  margin-right: auto; -} -a.thumbnail:hover, -a.thumbnail:focus, -a.thumbnail.active { -  border-color: #2780e3; -} -.thumbnail .caption { -  padding: 9px; -  color: #333333; -} -.alert { -  padding: 15px; -  margin-bottom: 21px; -  border: 1px solid transparent; -  border-radius: 0; -} -.alert h4 { -  margin-top: 0; -  color: inherit; -} -.alert .alert-link { -  font-weight: bold; -} -.alert > p, -.alert > ul { -  margin-bottom: 0; -} -.alert > p + p { -  margin-top: 5px; -} -.alert-dismissable, -.alert-dismissible { -  padding-right: 35px; -} -.alert-dismissable .close, -.alert-dismissible .close { -  position: relative; -  top: -2px; -  right: -21px; -  color: inherit; -} -.alert-success { -  background-color: #3fb618; -  border-color: #4e9f15; -  color: #ffffff; -} -.alert-success hr { -  border-top-color: #438912; -} -.alert-success .alert-link { -  color: #e6e6e6; -} -.alert-info { -  background-color: #9954bb; -  border-color: #7643a8; -  color: #ffffff; -} -.alert-info hr { -  border-top-color: #693c96; -} -.alert-info .alert-link { -  color: #e6e6e6; -} -.alert-warning { -  background-color: #ff7518; -  border-color: #ff4309; -  color: #ffffff; -} -.alert-warning hr { -  border-top-color: #ee3800; -} -.alert-warning .alert-link { -  color: #e6e6e6; -} -.alert-danger { -  background-color: #ff0039; -  border-color: #f0005e; -  color: #ffffff; -} -.alert-danger hr { -  border-top-color: #d60054; -} -.alert-danger .alert-link { -  color: #e6e6e6; -} -@-webkit-keyframes progress-bar-stripes { -  from { -    background-position: 40px 0; -  } -  to { -    background-position: 0 0; -  } -} -@keyframes progress-bar-stripes { -  from { -    background-position: 40px 0; -  } -  to { -    background-position: 0 0; -  } -} -.progress { -  overflow: hidden; -  height: 21px; -  margin-bottom: 21px; -  background-color: #cccccc; -  border-radius: 0; -  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); -  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); -} -.progress-bar { -  float: left; -  width: 0%; -  height: 100%; -  font-size: 13px; -  line-height: 21px; -  color: #ffffff; -  text-align: center; -  background-color: #2780e3; -  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); -  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); -  -webkit-transition: width 0.6s ease; -  -o-transition: width 0.6s ease; -  transition: width 0.6s ease; -} -.progress-striped .progress-bar, -.progress-bar-striped { -  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-size: 40px 40px; -} -.progress.active .progress-bar, -.progress-bar.active { -  -webkit-animation: progress-bar-stripes 2s linear infinite; -  -o-animation: progress-bar-stripes 2s linear infinite; -  animation: progress-bar-stripes 2s linear infinite; -} -.progress-bar-success { -  background-color: #3fb618; -} -.progress-striped .progress-bar-success { -  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -} -.progress-bar-info { -  background-color: #9954bb; -} -.progress-striped .progress-bar-info { -  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -} -.progress-bar-warning { -  background-color: #ff7518; -} -.progress-striped .progress-bar-warning { -  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -} -.progress-bar-danger { -  background-color: #ff0039; -} -.progress-striped .progress-bar-danger { -  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent); -} -.media { -  margin-top: 15px; -} -.media:first-child { -  margin-top: 0; -} -.media, -.media-body { -  zoom: 1; -  overflow: hidden; -} -.media-body { -  width: 10000px; -} -.media-object { -  display: block; -} -.media-right, -.media > .pull-right { -  padding-left: 10px; -} -.media-left, -.media > .pull-left { -  padding-right: 10px; -} -.media-left, -.media-right, -.media-body { -  display: table-cell; -  vertical-align: top; -} -.media-middle { -  vertical-align: middle; -} -.media-bottom { -  vertical-align: bottom; -} -.media-heading { -  margin-top: 0; -  margin-bottom: 5px; -} -.media-list { -  padding-left: 0; -  list-style: none; -} -.list-group { -  margin-bottom: 20px; -  padding-left: 0; -} -.list-group-item { -  position: relative; -  display: block; -  padding: 10px 15px; -  margin-bottom: -1px; -  background-color: #ffffff; -  border: 1px solid #dddddd; -} -.list-group-item:first-child { -  border-top-right-radius: 0; -  border-top-left-radius: 0; -} -.list-group-item:last-child { -  margin-bottom: 0; -  border-bottom-right-radius: 0; -  border-bottom-left-radius: 0; -} -a.list-group-item { -  color: #555555; -} -a.list-group-item .list-group-item-heading { -  color: #333333; -} -a.list-group-item:hover, -a.list-group-item:focus { -  text-decoration: none; -  color: #555555; -  background-color: #f5f5f5; -} -.list-group-item.disabled, -.list-group-item.disabled:hover, -.list-group-item.disabled:focus { -  background-color: #e6e6e6; -  color: #999999; -  cursor: not-allowed; -} -.list-group-item.disabled .list-group-item-heading, -.list-group-item.disabled:hover .list-group-item-heading, -.list-group-item.disabled:focus .list-group-item-heading { -  color: inherit; -} -.list-group-item.disabled .list-group-item-text, -.list-group-item.disabled:hover .list-group-item-text, -.list-group-item.disabled:focus .list-group-item-text { -  color: #999999; -} -.list-group-item.active, -.list-group-item.active:hover, -.list-group-item.active:focus { -  z-index: 2; -  color: #ffffff; -  background-color: #2780e3; -  border-color: #dddddd; -} -.list-group-item.active .list-group-item-heading, -.list-group-item.active:hover .list-group-item-heading, -.list-group-item.active:focus .list-group-item-heading, -.list-group-item.active .list-group-item-heading > small, -.list-group-item.active:hover .list-group-item-heading > small, -.list-group-item.active:focus .list-group-item-heading > small, -.list-group-item.active .list-group-item-heading > .small, -.list-group-item.active:hover .list-group-item-heading > .small, -.list-group-item.active:focus .list-group-item-heading > .small { -  color: inherit; -} -.list-group-item.active .list-group-item-text, -.list-group-item.active:hover .list-group-item-text, -.list-group-item.active:focus .list-group-item-text { -  color: #dceafa; -} -.list-group-item-success { -  color: #ffffff; -  background-color: #3fb618; -} -a.list-group-item-success { -  color: #ffffff; -} -a.list-group-item-success .list-group-item-heading { -  color: inherit; -} -a.list-group-item-success:hover, -a.list-group-item-success:focus { -  color: #ffffff; -  background-color: #379f15; -} -a.list-group-item-success.active, -a.list-group-item-success.active:hover, -a.list-group-item-success.active:focus { -  color: #fff; -  background-color: #ffffff; -  border-color: #ffffff; -} -.list-group-item-info { -  color: #ffffff; -  background-color: #9954bb; -} -a.list-group-item-info { -  color: #ffffff; -} -a.list-group-item-info .list-group-item-heading { -  color: inherit; -} -a.list-group-item-info:hover, -a.list-group-item-info:focus { -  color: #ffffff; -  background-color: #8d46b0; -} -a.list-group-item-info.active, -a.list-group-item-info.active:hover, -a.list-group-item-info.active:focus { -  color: #fff; -  background-color: #ffffff; -  border-color: #ffffff; -} -.list-group-item-warning { -  color: #ffffff; -  background-color: #ff7518; -} -a.list-group-item-warning { -  color: #ffffff; -} -a.list-group-item-warning .list-group-item-heading { -  color: inherit; -} -a.list-group-item-warning:hover, -a.list-group-item-warning:focus { -  color: #ffffff; -  background-color: #fe6600; -} -a.list-group-item-warning.active, -a.list-group-item-warning.active:hover, -a.list-group-item-warning.active:focus { -  color: #fff; -  background-color: #ffffff; -  border-color: #ffffff; -} -.list-group-item-danger { -  color: #ffffff; -  background-color: #ff0039; -} -a.list-group-item-danger { -  color: #ffffff; -} -a.list-group-item-danger .list-group-item-heading { -  color: inherit; -} -a.list-group-item-danger:hover, -a.list-group-item-danger:focus { -  color: #ffffff; -  background-color: #e60033; -} -a.list-group-item-danger.active, -a.list-group-item-danger.active:hover, -a.list-group-item-danger.active:focus { -  color: #fff; -  background-color: #ffffff; -  border-color: #ffffff; -} -.list-group-item-heading { -  margin-top: 0; -  margin-bottom: 5px; -} -.list-group-item-text { -  margin-bottom: 0; -  line-height: 1.3; -} -.panel { -  margin-bottom: 21px; -  background-color: #ffffff; -  border: 1px solid transparent; -  border-radius: 0; -  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05); -  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05); -} -.panel-body { -  padding: 15px; -} -.panel-heading { -  padding: 10px 15px; -  border-bottom: 1px solid transparent; -  border-top-right-radius: -1; -  border-top-left-radius: -1; -} -.panel-heading > .dropdown .dropdown-toggle { -  color: inherit; -} -.panel-title { -  margin-top: 0; -  margin-bottom: 0; -  font-size: 17px; -  color: inherit; -} -.panel-title > a, -.panel-title > small, -.panel-title > .small, -.panel-title > small > a, -.panel-title > .small > a { -  color: inherit; -} -.panel-footer { -  padding: 10px 15px; -  background-color: #f5f5f5; -  border-top: 1px solid #dddddd; -  border-bottom-right-radius: -1; -  border-bottom-left-radius: -1; -} -.panel > .list-group, -.panel > .panel-collapse > .list-group { -  margin-bottom: 0; -} -.panel > .list-group .list-group-item, -.panel > .panel-collapse > .list-group .list-group-item { -  border-width: 1px 0; -  border-radius: 0; -} -.panel > .list-group:first-child .list-group-item:first-child, -.panel > .panel-collapse > .list-group:first-child .list-group-item:first-child { -  border-top: 0; -  border-top-right-radius: -1; -  border-top-left-radius: -1; -} -.panel > .list-group:last-child .list-group-item:last-child, -.panel > .panel-collapse > .list-group:last-child .list-group-item:last-child { -  border-bottom: 0; -  border-bottom-right-radius: -1; -  border-bottom-left-radius: -1; -} -.panel-heading + .list-group .list-group-item:first-child { -  border-top-width: 0; -} -.list-group + .panel-footer { -  border-top-width: 0; -} -.panel > .table, -.panel > .table-responsive > .table, -.panel > .panel-collapse > .table { -  margin-bottom: 0; -} -.panel > .table caption, -.panel > .table-responsive > .table caption, -.panel > .panel-collapse > .table caption { -  padding-left: 15px; -  padding-right: 15px; -} -.panel > .table:first-child, -.panel > .table-responsive:first-child > .table:first-child { -  border-top-right-radius: -1; -  border-top-left-radius: -1; -} -.panel > .table:first-child > thead:first-child > tr:first-child, -.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child, -.panel > .table:first-child > tbody:first-child > tr:first-child, -.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child { -  border-top-left-radius: -1; -  border-top-right-radius: -1; -} -.panel > .table:first-child > thead:first-child > tr:first-child td:first-child, -.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:first-child, -.panel > .table:first-child > tbody:first-child > tr:first-child td:first-child, -.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:first-child, -.panel > .table:first-child > thead:first-child > tr:first-child th:first-child, -.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:first-child, -.panel > .table:first-child > tbody:first-child > tr:first-child th:first-child, -.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:first-child { -  border-top-left-radius: -1; -} -.panel > .table:first-child > thead:first-child > tr:first-child td:last-child, -.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:last-child, -.panel > .table:first-child > tbody:first-child > tr:first-child td:last-child, -.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:last-child, -.panel > .table:first-child > thead:first-child > tr:first-child th:last-child, -.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:last-child, -.panel > .table:first-child > tbody:first-child > tr:first-child th:last-child, -.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:last-child { -  border-top-right-radius: -1; -} -.panel > .table:last-child, -.panel > .table-responsive:last-child > .table:last-child { -  border-bottom-right-radius: -1; -  border-bottom-left-radius: -1; -} -.panel > .table:last-child > tbody:last-child > tr:last-child, -.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child, -.panel > .table:last-child > tfoot:last-child > tr:last-child, -.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child { -  border-bottom-left-radius: -1; -  border-bottom-right-radius: -1; -} -.panel > .table:last-child > tbody:last-child > tr:last-child td:first-child, -.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:first-child, -.panel > .table:last-child > tfoot:last-child > tr:last-child td:first-child, -.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:first-child, -.panel > .table:last-child > tbody:last-child > tr:last-child th:first-child, -.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:first-child, -.panel > .table:last-child > tfoot:last-child > tr:last-child th:first-child, -.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:first-child { -  border-bottom-left-radius: -1; -} -.panel > .table:last-child > tbody:last-child > tr:last-child td:last-child, -.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:last-child, -.panel > .table:last-child > tfoot:last-child > tr:last-child td:last-child, -.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:last-child, -.panel > .table:last-child > tbody:last-child > tr:last-child th:last-child, -.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:last-child, -.panel > .table:last-child > tfoot:last-child > tr:last-child th:last-child, -.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:last-child { -  border-bottom-right-radius: -1; -} -.panel > .panel-body + .table, -.panel > .panel-body + .table-responsive, -.panel > .table + .panel-body, -.panel > .table-responsive + .panel-body { -  border-top: 1px solid #dddddd; -} -.panel > .table > tbody:first-child > tr:first-child th, -.panel > .table > tbody:first-child > tr:first-child td { -  border-top: 0; -} -.panel > .table-bordered, -.panel > .table-responsive > .table-bordered { -  border: 0; -} -.panel > .table-bordered > thead > tr > th:first-child, -.panel > .table-responsive > .table-bordered > thead > tr > th:first-child, -.panel > .table-bordered > tbody > tr > th:first-child, -.panel > .table-responsive > .table-bordered > tbody > tr > th:first-child, -.panel > .table-bordered > tfoot > tr > th:first-child, -.panel > .table-responsive > .table-bordered > tfoot > tr > th:first-child, -.panel > .table-bordered > thead > tr > td:first-child, -.panel > .table-responsive > .table-bordered > thead > tr > td:first-child, -.panel > .table-bordered > tbody > tr > td:first-child, -.panel > .table-responsive > .table-bordered > tbody > tr > td:first-child, -.panel > .table-bordered > tfoot > tr > td:first-child, -.panel > .table-responsive > .table-bordered > tfoot > tr > td:first-child { -  border-left: 0; -} -.panel > .table-bordered > thead > tr > th:last-child, -.panel > .table-responsive > .table-bordered > thead > tr > th:last-child, -.panel > .table-bordered > tbody > tr > th:last-child, -.panel > .table-responsive > .table-bordered > tbody > tr > th:last-child, -.panel > .table-bordered > tfoot > tr > th:last-child, -.panel > .table-responsive > .table-bordered > tfoot > tr > th:last-child, -.panel > .table-bordered > thead > tr > td:last-child, -.panel > .table-responsive > .table-bordered > thead > tr > td:last-child, -.panel > .table-bordered > tbody > tr > td:last-child, -.panel > .table-responsive > .table-bordered > tbody > tr > td:last-child, -.panel > .table-bordered > tfoot > tr > td:last-child, -.panel > .table-responsive > .table-bordered > tfoot > tr > td:last-child { -  border-right: 0; -} -.panel > .table-bordered > thead > tr:first-child > td, -.panel > .table-responsive > .table-bordered > thead > tr:first-child > td, -.panel > .table-bordered > tbody > tr:first-child > td, -.panel > .table-responsive > .table-bordered > tbody > tr:first-child > td, -.panel > .table-bordered > thead > tr:first-child > th, -.panel > .table-responsive > .table-bordered > thead > tr:first-child > th, -.panel > .table-bordered > tbody > tr:first-child > th, -.panel > .table-responsive > .table-bordered > tbody > tr:first-child > th { -  border-bottom: 0; -} -.panel > .table-bordered > tbody > tr:last-child > td, -.panel > .table-responsive > .table-bordered > tbody > tr:last-child > td, -.panel > .table-bordered > tfoot > tr:last-child > td, -.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > td, -.panel > .table-bordered > tbody > tr:last-child > th, -.panel > .table-responsive > .table-bordered > tbody > tr:last-child > th, -.panel > .table-bordered > tfoot > tr:last-child > th, -.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > th { -  border-bottom: 0; -} -.panel > .table-responsive { -  border: 0; -  margin-bottom: 0; -} -.panel-group { -  margin-bottom: 21px; -} -.panel-group .panel { -  margin-bottom: 0; -  border-radius: 0; -} -.panel-group .panel + .panel { -  margin-top: 5px; -} -.panel-group .panel-heading { -  border-bottom: 0; -} -.panel-group .panel-heading + .panel-collapse > .panel-body, -.panel-group .panel-heading + .panel-collapse > .list-group { -  border-top: 1px solid #dddddd; -} -.panel-group .panel-footer { -  border-top: 0; -} -.panel-group .panel-footer + .panel-collapse .panel-body { -  border-bottom: 1px solid #dddddd; -} -.panel-default { -  border-color: #dddddd; -} -.panel-default > .panel-heading { -  color: #333333; -  background-color: #f5f5f5; -  border-color: #dddddd; -} -.panel-default > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #dddddd; -} -.panel-default > .panel-heading .badge { -  color: #f5f5f5; -  background-color: #333333; -} -.panel-default > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #dddddd; -} -.panel-primary { -  border-color: #2780e3; -} -.panel-primary > .panel-heading { -  color: #ffffff; -  background-color: #2780e3; -  border-color: #2780e3; -} -.panel-primary > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #2780e3; -} -.panel-primary > .panel-heading .badge { -  color: #2780e3; -  background-color: #ffffff; -} -.panel-primary > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #2780e3; -} -.panel-success { -  border-color: #4e9f15; -} -.panel-success > .panel-heading { -  color: #ffffff; -  background-color: #3fb618; -  border-color: #4e9f15; -} -.panel-success > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #4e9f15; -} -.panel-success > .panel-heading .badge { -  color: #3fb618; -  background-color: #ffffff; -} -.panel-success > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #4e9f15; -} -.panel-info { -  border-color: #7643a8; -} -.panel-info > .panel-heading { -  color: #ffffff; -  background-color: #9954bb; -  border-color: #7643a8; -} -.panel-info > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #7643a8; -} -.panel-info > .panel-heading .badge { -  color: #9954bb; -  background-color: #ffffff; -} -.panel-info > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #7643a8; -} -.panel-warning { -  border-color: #ff4309; -} -.panel-warning > .panel-heading { -  color: #ffffff; -  background-color: #ff7518; -  border-color: #ff4309; -} -.panel-warning > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #ff4309; -} -.panel-warning > .panel-heading .badge { -  color: #ff7518; -  background-color: #ffffff; -} -.panel-warning > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #ff4309; -} -.panel-danger { -  border-color: #f0005e; -} -.panel-danger > .panel-heading { -  color: #ffffff; -  background-color: #ff0039; -  border-color: #f0005e; -} -.panel-danger > .panel-heading + .panel-collapse > .panel-body { -  border-top-color: #f0005e; -} -.panel-danger > .panel-heading .badge { -  color: #ff0039; -  background-color: #ffffff; -} -.panel-danger > .panel-footer + .panel-collapse > .panel-body { -  border-bottom-color: #f0005e; -} -.embed-responsive { -  position: relative; -  display: block; -  height: 0; -  padding: 0; -  overflow: hidden; -} -.embed-responsive .embed-responsive-item, -.embed-responsive iframe, -.embed-responsive embed, -.embed-responsive object, -.embed-responsive video { -  position: absolute; -  top: 0; -  left: 0; -  bottom: 0; -  height: 100%; -  width: 100%; -  border: 0; -} -.embed-responsive-16by9 { -  padding-bottom: 56.25%; -} -.embed-responsive-4by3 { -  padding-bottom: 75%; -} -.well { -  min-height: 20px; -  padding: 19px; -  margin-bottom: 20px; -  background-color: #f5f5f5; -  border: 1px solid #e3e3e3; -  border-radius: 0; -  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05); -  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05); -} -.well blockquote { -  border-color: #ddd; -  border-color: rgba(0, 0, 0, 0.15); -} -.well-lg { -  padding: 24px; -  border-radius: 0; -} -.well-sm { -  padding: 9px; -  border-radius: 0; -} -.close { -  float: right; -  font-size: 22.5px; -  font-weight: bold; -  line-height: 1; -  color: #ffffff; -  text-shadow: 0 1px 0 #ffffff; -  opacity: 0.2; -  filter: alpha(opacity=20); -} -.close:hover, -.close:focus { -  color: #ffffff; -  text-decoration: none; -  cursor: pointer; -  opacity: 0.5; -  filter: alpha(opacity=50); -} -button.close { -  padding: 0; -  cursor: pointer; -  background: transparent; -  border: 0; -  -webkit-appearance: none; -} -.modal-open { -  overflow: hidden; -} -.modal { -  display: none; -  overflow: hidden; -  position: fixed; -  top: 0; -  right: 0; -  bottom: 0; -  left: 0; -  z-index: 1050; -  -webkit-overflow-scrolling: touch; -  outline: 0; -} -.modal.fade .modal-dialog { -  -webkit-transform: translate(0, -25%); -  -ms-transform: translate(0, -25%); -  -o-transform: translate(0, -25%); -  transform: translate(0, -25%); -  -webkit-transition: -webkit-transform 0.3s ease-out; -  -moz-transition: -moz-transform 0.3s ease-out; -  -o-transition: -o-transform 0.3s ease-out; -  transition: transform 0.3s ease-out; -} -.modal.in .modal-dialog { -  -webkit-transform: translate(0, 0); -  -ms-transform: translate(0, 0); -  -o-transform: translate(0, 0); -  transform: translate(0, 0); -} -.modal-open .modal { -  overflow-x: hidden; -  overflow-y: auto; -} -.modal-dialog { -  position: relative; -  width: auto; -  margin: 10px; -} -.modal-content { -  position: relative; -  background-color: #ffffff; -  border: 1px solid #999999; -  border: 1px solid transparent; -  border-radius: 0; -  -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5); -  box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5); -  background-clip: padding-box; -  outline: 0; -} -.modal-backdrop { -  position: fixed; -  top: 0; -  right: 0; -  bottom: 0; -  left: 0; -  z-index: 1040; -  background-color: #000000; -} -.modal-backdrop.fade { -  opacity: 0; -  filter: alpha(opacity=0); -} -.modal-backdrop.in { -  opacity: 0.5; -  filter: alpha(opacity=50); -} -.modal-header { -  padding: 15px; -  border-bottom: 1px solid #e5e5e5; -  min-height: 16.42857143px; -} -.modal-header .close { -  margin-top: -2px; -} -.modal-title { -  margin: 0; -  line-height: 1.42857143; -} -.modal-body { -  position: relative; -  padding: 20px; -} -.modal-footer { -  padding: 20px; -  text-align: right; -  border-top: 1px solid #e5e5e5; -} -.modal-footer .btn + .btn { -  margin-left: 5px; -  margin-bottom: 0; -} -.modal-footer .btn-group .btn + .btn { -  margin-left: -1px; -} -.modal-footer .btn-block + .btn-block { -  margin-left: 0; -} -.modal-scrollbar-measure { -  position: absolute; -  top: -9999px; -  width: 50px; -  height: 50px; -  overflow: scroll; -} -@media (min-width: 768px) { -  .modal-dialog { -    width: 600px; -    margin: 30px auto; -  } -  .modal-content { -    -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5); -    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5); -  } -  .modal-sm { -    width: 300px; -  } -} -@media (min-width: 992px) { -  .modal-lg { -    width: 900px; -  } -} -.tooltip { -  position: absolute; -  z-index: 1070; -  display: block; -  font-family: "Source Sans Pro", Calibri, Candara, Arial, sans-serif; -  font-size: 13px; -  font-weight: normal; -  line-height: 1.4; -  opacity: 0; -  filter: alpha(opacity=0); -} -.tooltip.in { -  opacity: 0.9; -  filter: alpha(opacity=90); -} -.tooltip.top { -  margin-top: -3px; -  padding: 5px 0; -} -.tooltip.right { -  margin-left: 3px; -  padding: 0 5px; -} -.tooltip.bottom { -  margin-top: 3px; -  padding: 5px 0; -} -.tooltip.left { -  margin-left: -3px; -  padding: 0 5px; -} -.tooltip-inner { -  max-width: 200px; -  padding: 3px 8px; -  color: #ffffff; -  text-align: center; -  text-decoration: none; -  background-color: #000000; -  border-radius: 0; -} -.tooltip-arrow { -  position: absolute; -  width: 0; -  height: 0; -  border-color: transparent; -  border-style: solid; -} -.tooltip.top .tooltip-arrow { -  bottom: 0; -  left: 50%; -  margin-left: -5px; -  border-width: 5px 5px 0; -  border-top-color: #000000; -} -.tooltip.top-left .tooltip-arrow { -  bottom: 0; -  right: 5px; -  margin-bottom: -5px; -  border-width: 5px 5px 0; -  border-top-color: #000000; -} -.tooltip.top-right .tooltip-arrow { -  bottom: 0; -  left: 5px; -  margin-bottom: -5px; -  border-width: 5px 5px 0; -  border-top-color: #000000; -} -.tooltip.right .tooltip-arrow { -  top: 50%; -  left: 0; -  margin-top: -5px; -  border-width: 5px 5px 5px 0; -  border-right-color: #000000; -} -.tooltip.left .tooltip-arrow { -  top: 50%; -  right: 0; -  margin-top: -5px; -  border-width: 5px 0 5px 5px; -  border-left-color: #000000; -} -.tooltip.bottom .tooltip-arrow { -  top: 0; -  left: 50%; -  margin-left: -5px; -  border-width: 0 5px 5px; -  border-bottom-color: #000000; -} -.tooltip.bottom-left .tooltip-arrow { -  top: 0; -  right: 5px; -  margin-top: -5px; -  border-width: 0 5px 5px; -  border-bottom-color: #000000; -} -.tooltip.bottom-right .tooltip-arrow { -  top: 0; -  left: 5px; -  margin-top: -5px; -  border-width: 0 5px 5px; -  border-bottom-color: #000000; -} -.popover { -  position: absolute; -  top: 0; -  left: 0; -  z-index: 1060; -  display: none; -  max-width: 276px; -  padding: 1px; -  font-family: "Source Sans Pro", Calibri, Candara, Arial, sans-serif; -  font-size: 15px; -  font-weight: normal; -  line-height: 1.42857143; -  text-align: left; -  background-color: #ffffff; -  background-clip: padding-box; -  border: 1px solid #cccccc; -  border: 1px solid rgba(0, 0, 0, 0.2); -  border-radius: 0; -  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); -  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); -  white-space: normal; -} -.popover.top { -  margin-top: -10px; -} -.popover.right { -  margin-left: 10px; -} -.popover.bottom { -  margin-top: 10px; -} -.popover.left { -  margin-left: -10px; -} -.popover-title { -  margin: 0; -  padding: 8px 14px; -  font-size: 15px; -  background-color: #f7f7f7; -  border-bottom: 1px solid #ebebeb; -  border-radius: -1 -1 0 0; -} -.popover-content { -  padding: 9px 14px; -} -.popover > .arrow, -.popover > .arrow:after { -  position: absolute; -  display: block; -  width: 0; -  height: 0; -  border-color: transparent; -  border-style: solid; -} -.popover > .arrow { -  border-width: 11px; -} -.popover > .arrow:after { -  border-width: 10px; -  content: ""; -} -.popover.top > .arrow { -  left: 50%; -  margin-left: -11px; -  border-bottom-width: 0; -  border-top-color: #999999; -  border-top-color: rgba(0, 0, 0, 0.25); -  bottom: -11px; -} -.popover.top > .arrow:after { -  content: " "; -  bottom: 1px; -  margin-left: -10px; -  border-bottom-width: 0; -  border-top-color: #ffffff; -} -.popover.right > .arrow { -  top: 50%; -  left: -11px; -  margin-top: -11px; -  border-left-width: 0; -  border-right-color: #999999; -  border-right-color: rgba(0, 0, 0, 0.25); -} -.popover.right > .arrow:after { -  content: " "; -  left: 1px; -  bottom: -10px; -  border-left-width: 0; -  border-right-color: #ffffff; -} -.popover.bottom > .arrow { -  left: 50%; -  margin-left: -11px; -  border-top-width: 0; -  border-bottom-color: #999999; -  border-bottom-color: rgba(0, 0, 0, 0.25); -  top: -11px; -} -.popover.bottom > .arrow:after { -  content: " "; -  top: 1px; -  margin-left: -10px; -  border-top-width: 0; -  border-bottom-color: #ffffff; -} -.popover.left > .arrow { -  top: 50%; -  right: -11px; -  margin-top: -11px; -  border-right-width: 0; -  border-left-color: #999999; -  border-left-color: rgba(0, 0, 0, 0.25); -} -.popover.left > .arrow:after { -  content: " "; -  right: 1px; -  border-right-width: 0; -  border-left-color: #ffffff; -  bottom: -10px; -} -.carousel { -  position: relative; -} -.carousel-inner { -  position: relative; -  overflow: hidden; -  width: 100%; -} -.carousel-inner > .item { -  display: none; -  position: relative; -  -webkit-transition: 0.6s ease-in-out left; -  -o-transition: 0.6s ease-in-out left; -  transition: 0.6s ease-in-out left; -} -.carousel-inner > .item > img, -.carousel-inner > .item > a > img { -  line-height: 1; -} -@media all and (transform-3d), (-webkit-transform-3d) { -  .carousel-inner > .item { -    -webkit-transition: -webkit-transform 0.6s ease-in-out; -    -moz-transition: -moz-transform 0.6s ease-in-out; -    -o-transition: -o-transform 0.6s ease-in-out; -    transition: transform 0.6s ease-in-out; -    -webkit-backface-visibility: hidden; -    -moz-backface-visibility: hidden; -    backface-visibility: hidden; -    -webkit-perspective: 1000; -    -moz-perspective: 1000; -    perspective: 1000; -  } -  .carousel-inner > .item.next, -  .carousel-inner > .item.active.right { -    -webkit-transform: translate3d(100%, 0, 0); -    transform: translate3d(100%, 0, 0); -    left: 0; -  } -  .carousel-inner > .item.prev, -  .carousel-inner > .item.active.left { -    -webkit-transform: translate3d(-100%, 0, 0); -    transform: translate3d(-100%, 0, 0); -    left: 0; -  } -  .carousel-inner > .item.next.left, -  .carousel-inner > .item.prev.right, -  .carousel-inner > .item.active { -    -webkit-transform: translate3d(0, 0, 0); -    transform: translate3d(0, 0, 0); -    left: 0; -  } -} -.carousel-inner > .active, -.carousel-inner > .next, -.carousel-inner > .prev { -  display: block; -} -.carousel-inner > .active { -  left: 0; -} -.carousel-inner > .next, -.carousel-inner > .prev { -  position: absolute; -  top: 0; -  width: 100%; -} -.carousel-inner > .next { -  left: 100%; -} -.carousel-inner > .prev { -  left: -100%; -} -.carousel-inner > .next.left, -.carousel-inner > .prev.right { -  left: 0; -} -.carousel-inner > .active.left { -  left: -100%; -} -.carousel-inner > .active.right { -  left: 100%; -} -.carousel-control { -  position: absolute; -  top: 0; -  left: 0; -  bottom: 0; -  width: 15%; -  opacity: 0.5; -  filter: alpha(opacity=50); -  font-size: 20px; -  color: #ffffff; -  text-align: center; -  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6); -} -.carousel-control.left { -  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%); -  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%); -  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%); -  background-repeat: repeat-x; -  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1); -} -.carousel-control.right { -  left: auto; -  right: 0; -  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%); -  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%); -  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%); -  background-repeat: repeat-x; -  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1); -} -.carousel-control:hover, -.carousel-control:focus { -  outline: 0; -  color: #ffffff; -  text-decoration: none; -  opacity: 0.9; -  filter: alpha(opacity=90); -} -.carousel-control .icon-prev, -.carousel-control .icon-next, -.carousel-control .glyphicon-chevron-left, -.carousel-control .glyphicon-chevron-right { -  position: absolute; -  top: 50%; -  z-index: 5; -  display: inline-block; -} -.carousel-control .icon-prev, -.carousel-control .glyphicon-chevron-left { -  left: 50%; -  margin-left: -10px; -} -.carousel-control .icon-next, -.carousel-control .glyphicon-chevron-right { -  right: 50%; -  margin-right: -10px; -} -.carousel-control .icon-prev, -.carousel-control .icon-next { -  width: 20px; -  height: 20px; -  margin-top: -10px; -  line-height: 1; -  font-family: serif; -} -.carousel-control .icon-prev:before { -  content: '\2039'; -} -.carousel-control .icon-next:before { -  content: '\203a'; -} -.carousel-indicators { -  position: absolute; -  bottom: 10px; -  left: 50%; -  z-index: 15; -  width: 60%; -  margin-left: -30%; -  padding-left: 0; -  list-style: none; -  text-align: center; -} -.carousel-indicators li { -  display: inline-block; -  width: 10px; -  height: 10px; -  margin: 1px; -  text-indent: -999px; -  border: 1px solid #ffffff; -  border-radius: 10px; -  cursor: pointer; -  background-color: #000 \9; -  background-color: rgba(0, 0, 0, 0); -} -.carousel-indicators .active { -  margin: 0; -  width: 12px; -  height: 12px; -  background-color: #ffffff; -} -.carousel-caption { -  position: absolute; -  left: 15%; -  right: 15%; -  bottom: 20px; -  z-index: 10; -  padding-top: 20px; -  padding-bottom: 20px; -  color: #ffffff; -  text-align: center; -  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6); -} -.carousel-caption .btn { -  text-shadow: none; -} -@media screen and (min-width: 768px) { -  .carousel-control .glyphicon-chevron-left, -  .carousel-control .glyphicon-chevron-right, -  .carousel-control .icon-prev, -  .carousel-control .icon-next { -    width: 30px; -    height: 30px; -    margin-top: -15px; -    font-size: 30px; -  } -  .carousel-control .glyphicon-chevron-left, -  .carousel-control .icon-prev { -    margin-left: -15px; -  } -  .carousel-control .glyphicon-chevron-right, -  .carousel-control .icon-next { -    margin-right: -15px; -  } -  .carousel-caption { -    left: 20%; -    right: 20%; -    padding-bottom: 30px; -  } -  .carousel-indicators { -    bottom: 20px; -  } -} -.clearfix:before, -.clearfix:after, -.dl-horizontal dd:before, -.dl-horizontal dd:after, -.container:before, -.container:after, -.container-fluid:before, -.container-fluid:after, -.row:before, -.row:after, -.form-horizontal .form-group:before, -.form-horizontal .form-group:after, -.btn-toolbar:before, -.btn-toolbar:after, -.btn-group-vertical > .btn-group:before, -.btn-group-vertical > .btn-group:after, -.nav:before, -.nav:after, -.navbar:before, -.navbar:after, -.navbar-header:before, -.navbar-header:after, -.navbar-collapse:before, -.navbar-collapse:after, -.pager:before, -.pager:after, -.panel-body:before, -.panel-body:after, -.modal-footer:before, -.modal-footer:after { -  content: " "; -  display: table; -} -.clearfix:after, -.dl-horizontal dd:after, -.container:after, -.container-fluid:after, -.row:after, -.form-horizontal .form-group:after, -.btn-toolbar:after, -.btn-group-vertical > .btn-group:after, -.nav:after, -.navbar:after, -.navbar-header:after, -.navbar-collapse:after, -.pager:after, -.panel-body:after, -.modal-footer:after { -  clear: both; -} -.center-block { -  display: block; -  margin-left: auto; -  margin-right: auto; -} -.pull-right { -  float: right !important; -} -.pull-left { -  float: left !important; -} -.hide { -  display: none !important; -} -.show { -  display: block !important; -} -.invisible { -  visibility: hidden; -} -.text-hide { -  font: 0/0 a; -  color: transparent; -  text-shadow: none; -  background-color: transparent; -  border: 0; -} -.hidden { -  display: none !important; -} -.affix { -  position: fixed; -} -@-ms-viewport { -  width: device-width; -} -.visible-xs, -.visible-sm, -.visible-md, -.visible-lg { -  display: none !important; -} -.visible-xs-block, -.visible-xs-inline, -.visible-xs-inline-block, -.visible-sm-block, -.visible-sm-inline, -.visible-sm-inline-block, -.visible-md-block, -.visible-md-inline, -.visible-md-inline-block, -.visible-lg-block, -.visible-lg-inline, -.visible-lg-inline-block { -  display: none !important; -} -@media (max-width: 767px) { -  .visible-xs { -    display: block !important; -  } -  table.visible-xs { -    display: table; -  } -  tr.visible-xs { -    display: table-row !important; -  } -  th.visible-xs, -  td.visible-xs { -    display: table-cell !important; -  } -} -@media (max-width: 767px) { -  .visible-xs-block { -    display: block !important; -  } -} -@media (max-width: 767px) { -  .visible-xs-inline { -    display: inline !important; -  } -} -@media (max-width: 767px) { -  .visible-xs-inline-block { -    display: inline-block !important; -  } -} -@media (min-width: 768px) and (max-width: 991px) { -  .visible-sm { -    display: block !important; -  } -  table.visible-sm { -    display: table; -  } -  tr.visible-sm { -    display: table-row !important; -  } -  th.visible-sm, -  td.visible-sm { -    display: table-cell !important; -  } -} -@media (min-width: 768px) and (max-width: 991px) { -  .visible-sm-block { -    display: block !important; -  } -} -@media (min-width: 768px) and (max-width: 991px) { -  .visible-sm-inline { -    display: inline !important; -  } -} -@media (min-width: 768px) and (max-width: 991px) { -  .visible-sm-inline-block { -    display: inline-block !important; -  } -} -@media (min-width: 992px) and (max-width: 1199px) { -  .visible-md { -    display: block !important; -  } -  table.visible-md { -    display: table; -  } -  tr.visible-md { -    display: table-row !important; -  } -  th.visible-md, -  td.visible-md { -    display: table-cell !important; -  } -} -@media (min-width: 992px) and (max-width: 1199px) { -  .visible-md-block { -    display: block !important; -  } -} -@media (min-width: 992px) and (max-width: 1199px) { -  .visible-md-inline { -    display: inline !important; -  } -} -@media (min-width: 992px) and (max-width: 1199px) { -  .visible-md-inline-block { -    display: inline-block !important; -  } -} -@media (min-width: 1200px) { -  .visible-lg { -    display: block !important; -  } -  table.visible-lg { -    display: table; -  } -  tr.visible-lg { -    display: table-row !important; -  } -  th.visible-lg, -  td.visible-lg { -    display: table-cell !important; -  } -} -@media (min-width: 1200px) { -  .visible-lg-block { -    display: block !important; -  } -} -@media (min-width: 1200px) { -  .visible-lg-inline { -    display: inline !important; -  } -} -@media (min-width: 1200px) { -  .visible-lg-inline-block { -    display: inline-block !important; -  } -} -@media (max-width: 767px) { -  .hidden-xs { -    display: none !important; -  } -} -@media (min-width: 768px) and (max-width: 991px) { -  .hidden-sm { -    display: none !important; -  } -} -@media (min-width: 992px) and (max-width: 1199px) { -  .hidden-md { -    display: none !important; -  } -} -@media (min-width: 1200px) { -  .hidden-lg { -    display: none !important; -  } -} -.visible-print { -  display: none !important; -} -@media print { -  .visible-print { -    display: block !important; -  } -  table.visible-print { -    display: table; -  } -  tr.visible-print { -    display: table-row !important; -  } -  th.visible-print, -  td.visible-print { -    display: table-cell !important; -  } -} -.visible-print-block { -  display: none !important; -} -@media print { -  .visible-print-block { -    display: block !important; -  } -} -.visible-print-inline { -  display: none !important; -} -@media print { -  .visible-print-inline { -    display: inline !important; -  } -} -.visible-print-inline-block { -  display: none !important; -} -@media print { -  .visible-print-inline-block { -    display: inline-block !important; -  } -} -@media print { -  .hidden-print { -    display: none !important; -  } -} - -/*# sourceMappingURL=01-vendor.css.map */
\ No newline at end of file diff --git a/doc-src/02-app.css b/doc-src/02-app.css deleted file mode 100644 index c7bd41ff..00000000 --- a/doc-src/02-app.css +++ /dev/null @@ -1,43 +0,0 @@ -.masthead { -  text-align: center; -  border-bottom: 0; -} -.frontpage .talks div { -  margin-bottom: 10px; -} -.nav-sidebar { -  background-color: #f0f0f0; -  margin-bottom: 20px; -} -.nav-sidebar li { -  line-height: 1.1; -} -.nav-sidebar li > a, -.nav-sidebar .nav-header { -  padding-left: 20px; -} -.nav-sidebar .nav-header { -  margin-top: 1em; -  font-size: 1.2em; -  font-weight: bold; -} -.nav-sidebar .active > a, -.nav-sidebar .active > a:hover, -.nav-sidebar .active > a:focus { -  color: #fff; -  background-color: #428bca; -} -.tablenum { -  font-weight: bold; -} -.nowrap { -  white-space: nowrap; -} -.page-header { -  margin: 0px 0 22px; -} -.page-header h1 { -  margin-top: 0px; -} - -/*# sourceMappingURL=02-app.css.map */
\ No newline at end of file diff --git a/doc-src/_layout.html b/doc-src/_layout.html deleted file mode 100644 index d0f42994..00000000 --- a/doc-src/_layout.html +++ /dev/null @@ -1,44 +0,0 @@ -<!DOCTYPE html> -<html> -    <head> -        <title>@!pageTitle!@</title> -        $!header!$ -    </head> -    <body> -        <div class="navbar navbar-default navbar-static-top"> -            <div class="container"> -                <div class="navbar-header"> -                    <a class="navbar-brand" href="@!urlTo("/index.html")!@"> -                        <img height="20px" src="@!urlTo("mitmproxy-long.png")!@"/> -                    </a> -                </div> -                <div class="navbar-header navbar-right"> -                    <a class="navbar-brand" hre="#">$!VERSION!$ docs</a> -                </div> -            </div> -        </div> - - -        <div class="container"> -          <div class="row"> -            <div class="col-md-3"> -                $!navbar!$ -            </div> -            <div class="col-md-9"> -                <div class="page-header"> -                <h1>@!this.title!@</h1> -                </div> -                $!body!$ -            </div> -          </div> -        </div> - -        <div class="container"> -          <hr> - -          <footer> -            <p>@!copyright!@</p> -          </footer> -        </div> -    </body> -</html> diff --git a/doc-src/_nav.html b/doc-src/_nav.html deleted file mode 100644 index a07684cb..00000000 --- a/doc-src/_nav.html +++ /dev/null @@ -1,50 +0,0 @@ -<ul class="nav nav-sidebar"> -    $!nav(idxpath, this, state)!$ -    $!nav("install.html", this, state)!$ -    $!nav("certinstall.html", this, state)!$ -    $!nav("howmitmproxy.html", this, state)!$ -    $!nav("modes.html", this, state)!$ - -    <li class="nav-header">Tools</li> -        $!nav("mitmproxy.html", this, state)!$ -        $!nav("mitmdump.html", this, state)!$ -        $!nav("config.html", this, state)!$ - -    <li class="nav-header">Features</li> -        $!nav("anticache.html", this, state)!$ - -        $!nav("filters.html", this, state)!$ -        $!nav("replacements.html", this, state)!$ -        $!nav("clientreplay.html", this, state)!$ -        $!nav("serverreplay.html", this, state)!$ -        $!nav("setheaders.html", this, state)!$ -        $!nav("passthrough.html", this, state)!$ -        $!nav("proxyauth.html", this, state)!$ -        $!nav("reverseproxy.html", this, state)!$ -        $!nav("responsestreaming.html", this, state)!$ -        $!nav("socksproxy.html", this, state)!$ -        $!nav("sticky.html", this, state)!$ -        $!nav("tcpproxy.html", this, state)!$ -        $!nav("upstreamproxy.html", this, state)!$ -        $!nav("upstreamcerts.html", this, state)!$ - - -    <li class="nav-header">Transparent Proxying</li> -        $!nav("transparent.html", this, state)!$ -        $!nav("transparent/linux.html", this, state)!$ -        $!nav("transparent/osx.html", this, state)!$ - -    <li class="nav-header">Scripting</li> -        $!nav("scripting/inlinescripts.html", this, state)!$ -        $!nav("scripting/libmproxy.html", this, state)!$ - -    <li class="nav-header">Tutorials</li> -        $!nav("tutorials/30second.html", this, state)!$ -        $!nav("tutorials/gamecenter.html", this, state)!$ -        $!nav("tutorials/transparent-dhcp.html", this, state)!$ - -    <li class="nav-header">Hacking</li> -        $!nav("dev/architecture.html", this, state)!$ -        $!nav("dev/testing.html", this, state)!$ -        $!nav("dev/sslkeylogfile.html", this, state)!$ -</ul> diff --git a/doc-src/certinstall-webapp.png b/doc-src/certinstall-webapp.pngBinary files differ deleted file mode 100644 index 10e795cd..00000000 --- a/doc-src/certinstall-webapp.png +++ /dev/null diff --git a/doc-src/certinstall.html b/doc-src/certinstall.html deleted file mode 100644 index 594049d9..00000000 --- a/doc-src/certinstall.html +++ /dev/null @@ -1,151 +0,0 @@ -## On This Page - -* [Introduction](#docIntro) -* [Quick Setup](#docQuick) -* [Installing the mitmproxy CA certificate manually](#docManual) -* [More on mitmproxy certificates](#docMore) -* [CA and cert files](#docCertfiles) -* [Using a custom certificate](#docCustom) -* [Using a client side certificate](#docClient) -* [Using a custom certificate authority](#docCA) - -## <a id="docIntro"></a>Introduction - -Mitmproxy can decrypt encrypted traffic on the fly, as long as the client -trusts its built-in certificate authority. Usually this means that the -mitmproxy CA certificates have to be installed on the client device. - -## <a id="docQuick"></a>Quick Setup - -By far the easiest way to install the mitmproxy certificates is to use the -built-in certificate installation app. To do this, just start mitmproxy and -configure your target device with the correct proxy settings. Now start a -browser on the device, and visit the magic domain **mitm.it**. You should see -something like this: - -<img class="img-responsive" src="@!urlTo("certinstall-webapp.png")!@" ></img> - -Click on the relevant icon, and follow the setup instructions for the platform -you're on, and you are good to go. - - -## <a id="docManual"></a>Installing the mitmproxy CA certificate manually - -Sometimes using the quick install app is not an option - Java or the iOS -Simulator spring to mind - or you just need to do it manually for some other -reason. Below is a list of pointers to manual certificate installation -documentation for some common platforms: - -<table class="table"> -    <tr> -        <td><a href="https://github.com/ADVTOOLS/ADVTrustStore#how-to-use-advtruststore"</a>iOS Simulator</td> -        <td><a href="http://docs.oracle.com/cd/E19906-01/820-4916/geygn/index.html">Java</a></td> -    </tr> -    <tr> -        <td><a href="http://kb.mit.edu/confluence/pages/viewpage.action?pageId=152600377">iOS</a></td> -        <td><a href="http://wiki.cacert.org/FAQ/ImportRootCert#Android_Phones_.26_Tablets">Android/Android Simulator</a></td> -    </tr> - -    <tr> -        <td><a href="http://windows.microsoft.com/en-ca/windows/import-export-certificates-private-keys#1TC=windows-7">Windows</a></td> -        <td><a href="https://support.apple.com/kb/PH7297?locale=en_US">Mac OS X</a></td> -    </tr> -    <tr> -        <td><a href="http://askubuntu.com/questions/73287/how-do-i-install-a-root-certificate/94861#94861">Ubuntu/Debian</a></td> -        <td><a href="https://wiki.mozilla.org/MozillaRootCertificate#Mozilla_Firefox">Firefox</a></td> -    </tr> -    <tr> -        <td><a href="https://code.google.com/p/chromium/wiki/LinuxCertManagement">Chrome on Linux</a></td> -    </tr> - -</table> - -## <a id="docMore"></a>More on mitmproxy certificates - -The first time __mitmproxy__ or __mitmdump__ is run, the mitmproxy Certificate -Authority(CA) is created in the config directory (~/.mitmproxy by default). -This CA is used for on-the-fly generation of dummy certificates for each of the -SSL sites that your client visits. Since your browser won't trust the -__mitmproxy__ CA out of the box , you will see an SSL certificate warning every -time you visit a new SSL domain through __mitmproxy__. When you are testing a -single site through a browser, just accepting the bogus SSL cert manually is -not too much trouble, but there are a many circumstances where you will want to -configure your testing system or browser to trust the __mitmproxy__ CA as a -signing root authority. - - -## <a id="docCertfiles"></a>CA and cert files - -The files created by mitmproxy in the .mitmproxy directory are as follows: - -<table class="table"> -    <tr> -        <td class="nowrap">mitmproxy-ca.pem</td> -        <td>The private key and certificate in PEM format.</td> -    </tr> -    <tr> -        <td class="nowrap">mitmproxy-ca-cert.pem</td> -        <td>The certificate in PEM format. Use this to distribute to most -        non-Windows platforms.</td> -    </tr> -    <tr> -        <td class="nowrap">mitmproxy-ca-cert.p12</td> -        <td>The certificate in PKCS12 format. For use on Windows.</td> -    </tr> -    <tr> -        <td class="nowrap">mitmproxy-ca-cert.cer</td> -        <td>Same file as .pem, but with an extension expected by some Android -        devices.</td> -    </tr> -</table> - - -## <a id="docCustom"></a>Using a custom certificate - -You can use your own certificate by passing the <kbd>--cert</kbd> option to -mitmproxy. mitmproxy then uses the provided certificate for interception of the -specified domains instead of generating a certificate signed by its own CA. - -The certificate file is expected to be in the PEM format.  You can include -intermediary certificates right below your leaf certificate, so that you PEM -file roughly looks like this: - -<pre> ------BEGIN PRIVATE KEY----- -<private key> ------END PRIVATE KEY----- ------BEGIN CERTIFICATE----- -<cert> ------END CERTIFICATE----- ------BEGIN CERTIFICATE----- -<intermediary cert (optional)> ------END CERTIFICATE----- -</pre> - -For example, you can generate a certificate in this format using these instructions: - -<pre class="terminal"> -$ openssl genrsa -out cert.key 2048 -$ openssl req -new -x509 -key cert.key -out cert.crt -    (Specify the mitm domain as Common Name, e.g. *.google.com) -$ cat cert.key cert.crt > cert.pem -$ mitmproxy --cert=cert.pem -</pre> - -## <a id="docClient"></a>Using a client side certificate - -You can use a client certificate by passing the <kbd>--client-certs -DIRECTORY</kbd> option to mitmproxy.  If you visit example.org, mitmproxy looks -for a file named example.org.pem in the specified directory and uses this as -the client cert. The certificate file needs to be in the PEM format and should -contain both the unencrypted private key and the certificate. - - -## <a id="docCA"></a>Using a custom certificate authority - -By default, mitmproxy will use <samp>~/.mitmproxy/mitmproxy-ca.pem</samp> as -the certificate authority to generate certificates for all domains for which no -custom certificate is provided (see above). You can use your own certificate -authority by passing the <kbd>--confdir</kbd> option to mitmproxy. Mitmproxy -will then look for <samp>mitmproxy-ca.pem</samp> in the specified directory. If -no such file exists, it will be generated automatically. diff --git a/doc-src/config.html b/doc-src/config.html deleted file mode 100644 index 46688575..00000000 --- a/doc-src/config.html +++ /dev/null @@ -1,86 +0,0 @@ - - -Mitmproxy is configured through a set of files in the users ~/.mitmproxy -directory.  - -<table class="table"> -	<tbody> -		<tr> -			<th>mitmproxy.conf</th>  -			<td>Settings for the <b>mitmproxy</b>. This file can contain any options supported by mitmproxy.</td> -		</tr> -		<tr> -			<th>mitmdump.conf</th>  -			<td>Settings for the <b>mitmdump</b>. This file can contain any options supported by mitmdump.</td> -		</tr> -		<tr> -			<th>common.conf</th> - -			<td>Settings shared between all command-line tools. Settings in -			this file are over-ridden by those in the tool-specific -			files. Only options shared by mitmproxy and mitmdump should be used in this file. </td> -		</tr> -	</tbody> -</table> - -# Syntax - -## Comments - -<pre> -# this is a comment -; this is also a comment (.ini style) ---- and this is a comment too (yaml style) -</pre> - -## Key/Value pairs - -- Keys and values are case-sensitive -- Whitespace is ignored -- Lists are comma-delimited, and enclosed in square brackets - -<pre> -name = value   # (.ini style)  -name: value    # (yaml style) ---name value   # (command-line option style) - -fruit = [apple, orange, lemon] -indexes = [1, 12, 35 , 40] -</pre> - -## Flags - -These are boolean options that take no value but true/false. - -<pre> -name = true    # (.ini style) -name ---name 	 	   # (command-line option style) -</pre> - -# Options - -The options available in the config files are precisely those available as -command-line flags, with the key being the option's long name. To get a -complete list of these, use the __--help__ option on each of the tools. Be -careful to only specify common options in the __common.conf__ file - -unsupported options in this file will be detected as an error on startup. - -# Examples - -## common.conf - -Note that __port__ is an option supported by all tools.  - -<pre class="code"> -port = 8080 -</pre> - - -## mitmproxy.conf - -<pre class="code"> -palette = light -</pre> - - diff --git a/doc-src/dev/architecture.html b/doc-src/dev/architecture.html deleted file mode 100644 index ae81b6c6..00000000 --- a/doc-src/dev/architecture.html +++ /dev/null @@ -1,8 +0,0 @@ -To give you a better understanding of how mitmproxy works, mitmproxy's -high-level architecture is detailed in the following graphic: - -<img class="img-responsive" src="@!urlTo('schematics/architecture.png')!@"> - -<a href="@!urlTo('schematics/architecture.pdf')!@">(architecture.pdf)</a> -<p>Please don't refrain from asking any further -questions on the mailing list, the IRC channel or the GitHub issue tracker.</p> diff --git a/doc-src/dev/index.py b/doc-src/dev/index.py deleted file mode 100644 index ddf100d0..00000000 --- a/doc-src/dev/index.py +++ /dev/null @@ -1,8 +0,0 @@ -from countershape import Page - -pages = [ -    Page("testing.html", "Testing"), -    Page("architecture.html", "Architecture"), -    Page("sslkeylogfile.html", "TLS Master Secrets"), -    #    Page("addingviews.html", "Writing Content Views"), -] diff --git a/doc-src/dev/sslkeylogfile.html b/doc-src/dev/sslkeylogfile.html deleted file mode 100644 index 1826fc2e..00000000 --- a/doc-src/dev/sslkeylogfile.html +++ /dev/null @@ -1,8 +0,0 @@ -The SSL master keys can be logged by mitmproxy so that external programs can decrypt TLS connections both from and to the proxy. -Key logging is enabled by setting the environment variable <samp>SSLKEYLOGFILE</samp> so that it points to a writable -text file. Recent versions of WireShark can use these log files to decrypt packets. -You can specify the key file path in WireShark via<br> -<samp>Edit → Preferences → Protocols → SSL → (Pre)-Master-Secret log filename</samp>. - - Note that <samp>SSLKEYLOGFILE</samp> is respected by other programs as well, e.g. Firefox and Chrome. -If this creates any issues, you can set <samp>MITMPROXY_SSLKEYLOGFILE</samp> alternatively.
\ No newline at end of file diff --git a/doc-src/dev/testing.html b/doc-src/dev/testing.html deleted file mode 100644 index 4cee29e8..00000000 --- a/doc-src/dev/testing.html +++ /dev/null @@ -1,43 +0,0 @@ - -All the mitmproxy projects strive to maintain 100% code coverage. In general, -patches and pull requests will be declined unless they're accompanied by a -suitable extension to the test suite.  - -Our tests are written for the [nose](https://nose.readthedocs.org/en/latest/). -At the point where you send your pull request, a command like this: - -<pre class="terminal"> -> nosetests --with-cov --cov-report term-missing ./test -</pre> - -Should give output something like this: - -<pre class="terminal"> -> ---------- coverage: platform darwin, python 2.7.2-final-0 -- -> Name                   Stmts   Miss  Cover   Missing -> ---------------------------------------------------- -> libmproxy/__init__         0      0   100% -> libmproxy/app              4      0   100% -> libmproxy/cmdline        100      0   100% -> libmproxy/controller      69      0   100% -> libmproxy/dump           150      0   100% -> libmproxy/encoding        39      0   100% -> libmproxy/filt           201      0   100% -> libmproxy/flow           891      0   100% -> libmproxy/proxy          427      0   100% -> libmproxy/script          27      0   100% -> libmproxy/utils          133      0   100% -> libmproxy/version          4      0   100% -> ---------------------------------------------------- -> TOTAL                   2045      0   100% -> ---------------------------------------------------- -> Ran 251 tests in 11.864s -</pre> - - -There are exceptions to the coverage requirement - for instance, much of the -console interface code can't sensibly be unit tested. These portions are -excluded from coverage analysis either in the **.coveragerc** file, or using -**#pragma no-cover** directives. To keep our coverage analysis relevant, we use -these measures as sparingly as possible. - diff --git a/doc-src/explicit.png b/doc-src/explicit.pngBinary files differ deleted file mode 100644 index c9ba26a7..00000000 --- a/doc-src/explicit.png +++ /dev/null diff --git a/doc-src/explicit_https.png b/doc-src/explicit_https.pngBinary files differ deleted file mode 100644 index 1f1ca023..00000000 --- a/doc-src/explicit_https.png +++ /dev/null diff --git a/doc-src/features/anticache.html b/doc-src/features/anticache.html deleted file mode 100644 index f42903e8..00000000 --- a/doc-src/features/anticache.html +++ /dev/null @@ -1,18 +0,0 @@ - -When the __anticache__ option is passed to mitmproxy, it removes headers -(__if-none-match__ and __if-modified-since__) that might elicit a -304-not-modified response from the server. This is useful when you want to make -sure you capture an HTTP exchange in its totality. It's also often used during -[client replay](@!urlTo("clientreplay.html")!@), when you want to make sure the -server responds with complete data. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>--anticache</td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>a</b></td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/clientreplay.html b/doc-src/features/clientreplay.html deleted file mode 100644 index 6638d078..00000000 --- a/doc-src/features/clientreplay.html +++ /dev/null @@ -1,22 +0,0 @@ - -Client-side replay does what it says on the tin: you provide a previously saved -HTTP conversation, and mitmproxy replays the client requests one by one. Note -that mitmproxy serializes the requests, waiting for a response from the server -before starting the next request. This might differ from the recorded -conversation, where requests may have been made concurrently. - -You may want to use client-side replay in conjunction with the -[anticache](@!urlTo("anticache.html")!@) option, to make sure the server -responds with complete data.  - - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>-c path</td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>c</b></td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/filters.html b/doc-src/features/filters.html deleted file mode 100644 index c7f0f78b..00000000 --- a/doc-src/features/filters.html +++ /dev/null @@ -1,36 +0,0 @@ - -Many commands in __mitmproxy__ and __mitmdump__ take a filter expression. -Filter expressions consist of the following operators: - -<table class="table"> -    <tbody> -    <!--(for i in filt_help)--> -        <tr> -            <td class="filt_cmd">@!i[0]!@</td> -            <td class="filt_help">@!i[1]!@</td> -        </tr> -    <!--(end)--> -    </tbody> -</table> - -- Regexes are Python-style -- Regexes can be specified as quoted strings -- Header matching (~h, ~hq, ~hs) is against a string of the form "name: value". -- Strings with no operators are matched against the request URL. -- The default binary operator is &. - -Examples -======== - -URL containing "google.com": - -    google\.com - -Requests whose body contains the string "test": - -    ~q ~b test - -Anything but requests with a text/html content type: - -    !(~q & ~t \"text/html\") - diff --git a/doc-src/features/index.py b/doc-src/features/index.py deleted file mode 100644 index fdab1714..00000000 --- a/doc-src/features/index.py +++ /dev/null @@ -1,19 +0,0 @@ -from countershape import Page - -pages = [ -    Page("anticache.html", "Anticache"), -    Page("clientreplay.html", "Client-side replay"), -    Page("filters.html", "Filter expressions"), -    Page("passthrough.html", "Ignore Domains"), -    Page("proxyauth.html", "Proxy Authentication"), -    Page("replacements.html", "Replacements"), -    Page("responsestreaming.html", "Response Streaming"), -    Page("reverseproxy.html", "Reverse proxy mode"), -    Page("socksproxy.html", "SOCKS Mode"), -    Page("setheaders.html", "Set Headers"), -    Page("serverreplay.html", "Server-side replay"), -    Page("sticky.html", "Sticky cookies and auth"), -    Page("tcpproxy.html", "TCP Proxy"), -    Page("upstreamcerts.html", "Upstream Certs"), -    Page("upstreamproxy.html", "Upstream proxy mode"), -] diff --git a/doc-src/features/passthrough.html b/doc-src/features/passthrough.html deleted file mode 100644 index 101a337a..00000000 --- a/doc-src/features/passthrough.html +++ /dev/null @@ -1,84 +0,0 @@ -There are two main reasons why you may want to exempt some traffic from mitmproxy's interception mechanism: - -- **Certificate pinning:** Some traffic is is protected using -  [certificate pinning](https://security.stackexchange.com/questions/29988/what-is-certificate-pinning) and mitmproxy's -  interception leads to errors. For example, Windows Update or the Apple App Store fail to work if mitmproxy is active. -- **Convenience:** You really don't care about some parts of the traffic and just want them to go away. - -If you want to peek into (SSL-protected) non-HTTP connections, check out the [tcp proxy](@!urlTo("tcpproxy.html")!@) feature. -If you want to ignore traffic from mitmproxy's processing because of large response bodies, take a look at the -[response streaming](@!urlTo("responsestreaming.html")!@) feature. - -## How it works - - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>--ignore regex</td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>I</b></td> -        </tr> -    </tbody> -</table> - - -mitmproxy allows you to specify a regex which is matched against a <code>host:port</code> string (e.g. "example.com:443") -to determine hosts that should be excluded. - -There are two important quirks to consider: - -- **In transparent mode, the ignore pattern is matched against the IP.** While we usually infer the hostname from the -  Host header if the --host argument is passed to mitmproxy, we do not have access to this information before the SSL -  handshake. -- In regular mode, explicit HTTP requests are never ignored.[^explicithttp] The ignore pattern is applied on CONNECT -  requests, which initiate HTTPS or clear-text WebSocket connections. - - -### Tutorial - -If you just want to ignore one specific domain, there's usually a bulletproof method to do so: - -1. Run mitmproxy or mitmdump in verbose mode (-v) and observe the host:port information in the serverconnect -messages. mitmproxy will filter on these. -2. Take the host:port string, surround it with ^ and $, escape all dots (. becomes \\.) -and use this as your ignore pattern: - -<pre class="terminal"> -$ mitmdump -v -127.0.0.1:50588: clientconnect -127.0.0.1:50588: request -  -> CONNECT example.com:443 HTTP/1.1 -127.0.0.1:50588: Set new server address: example.com:443 -127.0.0.1:50588: serverconnect -  -> example.com:443 -^C -$ mitmproxy --ignore ^example\.com:443$ -</pre> - -Here are some other examples for ignore patterns: -<pre> -# Exempt traffic from the iOS App Store (the regex is lax, but usually just works): ---ignore apple.com:443 -# "Correct" version without false-positives: ---ignore '^(.+\.)?apple\.com:443$' - -# Ignore example.com, but not its subdomains: ---ignore '^example.com:' - -# Ignore everything but example.com and mitmproxy.org: ---ignore '^(?!example\.com)(?!mitmproxy\.org)' - -# Transparent mode: ---ignore 17\.178\.96\.59:443 -# IP address range: ---ignore 17\.178\.\d+\.\d+:443 -</pre> - -### See Also - -- [TCP Proxy](@!urlTo("tcpproxy.html")!@) -- [Response Streaming](@!urlTo("responsestreaming.html")!@) - -[^explicithttp]: This stems from an limitation of explicit HTTP proxying: A single connection can be re-used for multiple target domains - a <code>GET http://example.com/</code> request may be followed by a <code>GET http://evil.com/</code> request on the same connection. If we start to ignore the connection after the first request, we would miss the relevant second one. diff --git a/doc-src/features/proxyauth.html b/doc-src/features/proxyauth.html deleted file mode 100644 index c22d50f3..00000000 --- a/doc-src/features/proxyauth.html +++ /dev/null @@ -1,26 +0,0 @@ - -Asks the user for authentication before they are permitted to use the proxy. -Authentication headers are stripped from the flows, so they are not passed to -upstream servers. For now, only HTTP Basic authentication is supported. The -proxy auth options are ignored if the proxy is in transparent or reverse proxy -mode. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> -            <td> -                <ul> -                    <li>--nonanonymous</li> - -                    <li>--singleuser USER</li> - -                    <li>--htpasswd PATH</li> -                </ul> -            </td> -        </tr> -    </tbody> -</table> - - - diff --git a/doc-src/features/replacements.html b/doc-src/features/replacements.html deleted file mode 100644 index 6de06d5e..00000000 --- a/doc-src/features/replacements.html +++ /dev/null @@ -1,74 +0,0 @@ -Mitmproxy lets you specify an arbitrary number of patterns that define text -replacements within flows. Each pattern has 3 components: a filter that defines -which flows a replacement applies to, a regular expression that defines what -gets replaced, and a target value that defines what is substituted in. - -Replace hooks fire when either a client request or a server response is -received. Only the matching flow component is affected: so, for example, if a -replace hook is triggered on server response, the replacement is only run on -the Response object leaving the Request intact. You control whether the hook -triggers on the request, response or both using the filter pattern. If you need -finer-grained control than this, it's simple to create a script using the -replacement API on Flow components. - -Replacement hooks are extremely handy in interactive testing of applications. -For instance you can use a replace hook to replace the text "XSS" with a -complicated XSS exploit, and then "inject" the exploit simply by interacting -with the application through the browser. When used with tools like Firebug and -mitmproxy's own interception abilities, replacement hooks can be an amazingly -flexible and powerful feature. - - -## On the command-line - -The replacement hook command-line options use a compact syntax to make it easy -to specify all three components at once. The general form is as follows: - -    /patt/regex/replacement - -Here, __patt__ is a mitmproxy filter expression, __regex__ is a valid Python -regular expression, and __replacement__ is a string literal. The first -character in the expression (__/__ in this case) defines what the separation -character is. Here's an example of a valid expression that replaces "foo" with -"bar" in all requests: - -    :~q:foo:bar - -In practice, it's pretty common for the replacement literal to be long and -complex. For instance, it might be an XSS exploit that weighs in at hundreds or -thousands of characters. To cope with this, there's a variation of the -replacement hook specifier that lets you load the replacement text from a file. -So, you might start __mitmdump__ as follows: - -<pre class="terminal"> -mitmdump --replace-from-file :~q:foo:~/xss-exploit -</pre> - -This will load the replacement text from the file __~/xss-exploit__. - -Both the _--replace_ and _--replace-from-file_ flags can be passed multiple -times. - - -## Interactively - -The _R_ shortcut key in the mitmproxy options menu (_o_) lets you add and edit -replacement hooks using a built-in editor. The context-sensitive help (_?_) has -complete usage information. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> -            <td> -                <ul> -                    <li>--replace</li> -                    <li>--replace-from-file</li> -                </ul> -            </td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>R</b></td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/responsestreaming.html b/doc-src/features/responsestreaming.html deleted file mode 100644 index 6511e913..00000000 --- a/doc-src/features/responsestreaming.html +++ /dev/null @@ -1,58 +0,0 @@ -By using mitmproxy's streaming feature, response contents can be passed to the client incrementally before they have been fully received by the proxy. -This is especially useful for large binary files such as videos, where buffering the whole file slows down the client's browser. - -By default, mitmproxy will read the entire response, perform any indicated -manipulations on it and then send the (possibly modified) response to -the client. In some cases this is undesirable and you may wish to "stream" -the reponse back to the client. When streaming is enabled, the response is -not buffered on the proxy but directly sent back to the client instead. - -<h2>On the command-line</h2> - -Streaming can be enabled on the command line for all response bodies exceeding a certain size.  The SIZE argument understands -k/m/g suffixes, e.g. 3m for 3 megabytes. - -<table class="table"> -    <tbody> -    <tr> -        <th width="20%">command-line</th> -        <td> -            --stream SIZE -        </td> -    </tr> -    </tbody> -</table> - - -<h2>Caveats</h2> - -When response streaming is enabled, <strong>streamed response contents will not be -    recorded or preserved in any way.</strong> - -When response streaming is enabled, the response body cannot be modified. - -<h2>Customizing Response Streaming</h2> - -You can also use an <a href="@!urlTo("scripting/inlinescripts.html")!@">inline script</a> to customize exactly -which responses are streamed. - -Responses that should be tagged for streaming by setting their respective .stream attribute to True: - -$!example("examples/stream.py")!$ - -<h2>Implementation Details</h2> - -When response streaming is enabled, portions of the code which would have otherwise performed changes -on the response body will see an empty response body instead (<code>libmproxy.protocol.http.CONTENT_MISSING</code>). Any modifications will be ignored. - -Streamed responses are usually sent in chunks of 4096 bytes. If the response is sent with a <code>Transfer-Encoding: -    chunked</code> header, the response will be streamed one chunk at a time. - -<h2>Modifying streamed data</h2> -If the <code>.stream</code> attribute is callable, .stream will work as a hook in chunk data processing. - -$!example("examples/stream_modify.py")!$ - -### See Also - -- [Ignore Domains](@!urlTo("passthrough.html")!@) diff --git a/doc-src/features/reverseproxy.html b/doc-src/features/reverseproxy.html deleted file mode 100644 index af5a5c53..00000000 --- a/doc-src/features/reverseproxy.html +++ /dev/null @@ -1,47 +0,0 @@ - -In reverse proxy mode, mitmproxy accepts standard HTTP requests and forwards -them to the specified upstream server. This is in contrast to -<a href="@!urlTo("upstreamproxy.html")!@">upstream proxy mode</a>, in which -mitmproxy forwards HTTP proxy requests to an upstream proxy server. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>-R <i>scheme</i>://hostname[:port]</td> -        </tr> -    </tbody> -</table> - -Here, **scheme** signifies if the proxy should use TLS to connect to the server. -mitmproxy accepts both encrypted and unencrypted requests and transforms them to what the server -expects. - -    mitmdump -R https://httpbin.org -p 80 -    mitmdump -R https://httpbin.org -p 443 - - -### Host Header - -In reverse proxy mode, mitmproxy does not rewrite the host header. While often useful, this -may lead to issues with public web servers. For example, consider the following scenario: - -    $ python mitmdump -d -R http://example.com/ & -    $ curl http://localhost:8080/ - -    >> GET https://example.com/ -        Host: localhost:8080 -        User-Agent: curl/7.35.0 -        [...] - -    << 404 Not Found 345B - -Since the Host header doesn't match <samp>example.com</samp>, an error is returned.<br> -There are two ways to solve this: -<ol> -    <li>Modify the hosts file of your OS so that example.com resolves to 127.0.0.1.</li> -    <li> -        Instruct mitmproxy to rewrite the host header by passing <kbd>‑‑setheader :~q:Host:example.com</kbd>. -        However, keep in mind that absolute URLs within the returned document or HTTP redirects will cause the client application -        to bypass the proxy. -    </li> -</ol>
\ No newline at end of file diff --git a/doc-src/features/serverreplay.html b/doc-src/features/serverreplay.html deleted file mode 100644 index 1282be06..00000000 --- a/doc-src/features/serverreplay.html +++ /dev/null @@ -1,35 +0,0 @@ - -- command-line: _-S path_  -- mitmproxy shortcut: _S_ - -Server-side replay lets us replay server responses from a saved HTTP -conversation. - -Matching requests with responses --------------------------------- - -By default, __mitmproxy__ excludes request headers when matching incoming -requests with responses from the replay file. This works in most circumstances, -and makes it possible to replay server responses in situations where request -headers would naturally vary, e.g. using a different user agent. The _--rheader -headername_ command-line option allows you to override this behaviour by -specifying individual headers that should be included in matching. - - -Response refreshing -------------------- - -Simply replaying server responses without modification will often result in -unexpected behaviour. For example cookie timeouts that were in the future at -the time a conversation was recorded might be in the past at the time it is -replayed. By default, __mitmproxy__ refreshes server responses before sending -them to the client. The __date__, __expires__ and __last-modified__ headers are -all updated to have the same relative time offset as they had at the time of -recording. So, if they were in the past at the time of recording, they will be -in the past at the time of replay, and vice versa. Cookie expiry times are -updated in a similar way. - -You can turn off response refreshing using the _--norefresh_ argument, or using -the _o_ options shortcut within __mitmproxy__. - - diff --git a/doc-src/features/setheaders.html b/doc-src/features/setheaders.html deleted file mode 100644 index 79850e35..00000000 --- a/doc-src/features/setheaders.html +++ /dev/null @@ -1,18 +0,0 @@ - -This feature lets you specify a set of headers to be added to requests or -responses, based on a filter pattern. You can specify these either on the -command-line, or through an interactive editor in mitmproxy. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> -            <td> -                --setheader PATTERN -            </td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>H</b></td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/socksproxy.html b/doc-src/features/socksproxy.html deleted file mode 100644 index f436cbf5..00000000 --- a/doc-src/features/socksproxy.html +++ /dev/null @@ -1,10 +0,0 @@ - -In this mode, mitmproxy acts as a SOCKS5 proxy server. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>--socks</td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/sticky.html b/doc-src/features/sticky.html deleted file mode 100644 index 18e6a4c5..00000000 --- a/doc-src/features/sticky.html +++ /dev/null @@ -1,60 +0,0 @@ - -## Sticky cookies - -When the sticky cookie option is set, __mitmproxy__ will add the cookie most -recently set by the server to any cookie-less request. Consider a service that -sets a cookie to track the session after authentication. Using sticky cookies, -you can fire up mitmproxy, and authenticate to a service as you usually would -using a browser. After authentication, you can request authenticated resources -through mitmproxy as if they were unauthenticated, because mitmproxy will -automatically add the session tracking cookie to requests. Among other things, -this lets you script interactions with authenticated resources (using tools -like wget or curl) without having to worry about authentication. - -Sticky cookies are especially powerful when used in conjunction with [client -replay](@!urlTo("clientreplay.html")!@) - you can record the authentication -process once, and simply replay it on startup every time you need to interact -with the secured resources. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> -            <td> -                <ul> -                    <li>-t FILTER</li> -                </ul> -            </td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>t</b></td> -        </tr> -    </tbody> -</table> - - -## Sticky auth - -The sticky auth option is analogous to the sticky cookie option, in that HTTP -__Authorization__ headers are simply replayed to the server once they have been -seen. This is enough to allow you to access a server resource using HTTP Basic -authentication through the proxy. Note that __mitmproxy__ doesn't (yet) support -replay of HTTP Digest authentication. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> -            <td> -                <ul> -                    <li>-u FILTER</li> -                </ul> -            </td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>A</b></td> -        </tr> -    </tbody> -</table> - - diff --git a/doc-src/features/tcpproxy.html b/doc-src/features/tcpproxy.html deleted file mode 100644 index 48dd92f1..00000000 --- a/doc-src/features/tcpproxy.html +++ /dev/null @@ -1,30 +0,0 @@ -WebSockets or other non-HTTP protocols are not supported by mitmproxy yet. However, you can exempt hostnames from -processing, so that mitmproxy acts as a generic TCP forwarder. This feature is closely related to the -[ignore domains](@!urlTo("passthrough.html")!@) functionality, but differs in two important aspects: - -- The raw TCP messages are printed to the event log. -- SSL connections will be intercepted. - -Please note that message interception or modification are not possible yet. -If you are not interested in the raw TCP messages, you should use the ignore domains feature. - -## How it works - - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>--tcp HOST</td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>T</b></td> -        </tr> -    </tbody> -</table> - -For a detailed description on the structure of the hostname pattern, please refer to the [Ignore Domains](@!urlTo("passthrough.html")!@) feature. - -### See Also - -- [Ignore Domains](@!urlTo("passthrough.html")!@) -- [Response Streaming](@!urlTo("responsestreaming.html")!@) diff --git a/doc-src/features/upstreamcerts.html b/doc-src/features/upstreamcerts.html deleted file mode 100644 index a86ed67d..00000000 --- a/doc-src/features/upstreamcerts.html +++ /dev/null @@ -1,24 +0,0 @@ -When mitmproxy receives a connection destined for an SSL-protected service, it -freezes the connection before reading its request data, and makes a connection -to the upstream server to "sniff" the contents of its SSL certificate. The -information gained - the __Common Name__ and __Subject Alternative Names__ - is -then used to generate the interception certificate, which is sent to the client -so the connection can continue. - -This rather intricate little dance lets us seamlessly generate correct -certificates even if the client has specifed only an IP address rather than the -hostname. It also means that we don't need to sniff additional data to generate -certs in transparent mode. - -Upstream cert sniffing is on by default, and can optionally be turned off. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>--no-upstream-cert</td> -        </tr> -        <tr> -            <th>mitmproxy shortcut</th> <td><b>o</b> then <b>U</b></td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/features/upstreamproxy.html b/doc-src/features/upstreamproxy.html deleted file mode 100644 index bb354cd3..00000000 --- a/doc-src/features/upstreamproxy.html +++ /dev/null @@ -1,13 +0,0 @@ - -In this mode, mitmproxy accepts proxy requests and unconditionally forwards all -requests to a specified upstream proxy server. This is in contrast to <a -href="@!urlTo("reverseproxy.html")!@">reverse proxy mode</a>, in which -mitmproxy forwards ordinary HTTP requests to an upstream server. - -<table class="table"> -    <tbody> -        <tr> -            <th width="20%">command-line</th> <td>-U http://hostname[:port]</td> -        </tr> -    </tbody> -</table> diff --git a/doc-src/howmitmproxy.html b/doc-src/howmitmproxy.html deleted file mode 100644 index 16b5f722..00000000 --- a/doc-src/howmitmproxy.html +++ /dev/null @@ -1,351 +0,0 @@ - - -Mitmproxy is an enormously flexible tool. Knowing exactly how the proxying -process works will help you deploy it creatively, and take into account its -fundamental assumptions and how to work around them. This document explains -mitmproxy's proxy mechanism in detail, starting with the simplest unencrypted -explicit proxying, and working up to the most complicated interaction - -transparent proxying of SSL-protected traffic[^ssl] in the presence of -[SNI](http://en.wikipedia.org/wiki/Server_Name_Indication). - - -<div class="page-header"> -    <h1>Explicit HTTP</h1> -</div> - -Configuring the client to use mitmproxy as an explicit proxy is the simplest -and most reliable way to intercept traffic. The proxy protocol is codified in -the [HTTP RFC](http://www.ietf.org/rfc/rfc2068.txt), so the behaviour of both -the client and the server is well defined, and usually reliable. In the -simplest possible interaction with mitmproxy, a client connects directly to the -proxy, and makes a request that looks like this: - -<pre>GET http://example.com/index.html HTTP/1.1</pre> - -This is a proxy GET request - an extended form of the vanilla HTTP GET request -that includes a schema and host specification, and it includes all the -information mitmproxy needs to proceed. - -<img class="img-responsive" src="explicit.png"/> - -<table class="table"> -    <tbody> -        <tr> - -            <td><b>1</b></td> - -            <td>The client connects to the proxy and makes a request.</td> - -        </tr> - -        <tr> - -            <td><b>2</b></td> - -            <td>Mitmproxy connects to the upstream server and simply forwards -            the request on.</td> - -        </tr> -    </tbody> -</table> - - -<div class="page-header"> -    <h1>Explicit HTTPS</h1> -</div> - -The process for an explicitly proxied HTTPS connection is quite different. The -client connects to the proxy and makes a request that looks like this: - -<pre>CONNECT example.com:443 HTTP/1.1</pre> - -A conventional proxy can neither view nor manipulate an SSL-encrypted data -stream, so a CONNECT request simply asks the proxy to open a pipe between the -client and server. The proxy here is just a facilitator - it blindly forwards -data in both directions without knowing anything about the contents. The -negotiation of the SSL connection happens over this pipe, and the subsequent -flow of requests and responses are completely opaque to the proxy. - -## The MITM in mitmproxy - -This is where mitmproxy's fundamental trick comes into play. The MITM in its -name stands for Man-In-The-Middle - a reference to the process we use to -intercept and interfere with these theoretically opaque data streams. The basic -idea is to pretend to be the server to the client, and pretend to be the client -to the server, while we sit in the middle decoding traffic from both sides. The -tricky part is that the [Certificate -Authority](http://en.wikipedia.org/wiki/Certificate_authority) system is -designed to prevent exactly this attack, by allowing a trusted third-party to -cryptographically sign a server's SSL certificates to verify that they are -legit. If this signature doesn't match or is from a non-trusted party, a secure -client will simply drop the connection and refuse to proceed. Despite the many -shortcomings of the CA system as it exists today, this is usually fatal to -attempts to MITM an SSL connection for analysis. Our answer to this conundrum -is to become a trusted Certificate Authority ourselves. Mitmproxy includes a -full CA implementation that generates interception certificates on the fly. To -get the client to trust these certificates, we [register mitmproxy as a trusted -CA with the device manually](@!urlTo("certinstall.html")!@). - -## Complication 1: What's the remote hostname? - -To proceed with this plan, we need to know the domain name to use in the -interception certificate - the client will verify that the certificate is for -the domain it's connecting to, and abort if this is not the case. At first -blush, it seems that the CONNECT request above gives us all we need - in this -example, both of these values are "example.com".  But what if the client had -initiated the connection as follows: - -<pre>CONNECT 10.1.1.1:443 HTTP/1.1</pre> - -Using the IP address is perfectly legitimate because it gives us enough -information to initiate the pipe, even though it doesn't reveal the remote -hostname. - -Mitmproxy has a cunning mechanism that smooths this over - [upstream -certificate sniffing](@!urlTo("features/upstreamcerts.html")!@). As soon as we -see the CONNECT request, we pause the client part of the conversation, and -initiate a simultaneous connection to the server. We complete the SSL handshake -with the server, and inspect the certificates it used. Now, we use the Common -Name in the upstream SSL certificates to generate the dummy certificate for the -client. Voila, we have the correct hostname to present to the client, even if -it was never specified. - - -## Complication 2: Subject Alternative Name - -Enter the next complication. Sometimes, the certificate Common Name is not, in -fact, the hostname that the client is connecting to. This is because of the -optional [Subject Alternative -Name](http://en.wikipedia.org/wiki/SubjectAltName) field in the SSL certificate -that allows an arbitrary number of alternative domains to be specified. If the -expected domain matches any of these, the client will proceed, even though the -domain doesn't match the certificate Common Name. The answer here is simple: -when we extract the CN from the upstream cert, we also extract the SANs, and -add them to the generated dummy certificate. - - -## Complication 3: Server Name Indication - -One of the big limitations of vanilla SSL is that each certificate requires its -own IP address. This means that you couldn't do virtual hosting where multiple -domains with independent certificates share the same IP address. In a world -with a rapidly shrinking IPv4 address pool this is a problem, and we have a -solution in the form of the [Server Name -Indication](http://en.wikipedia.org/wiki/Server_Name_Indication) extension to -the SSL and TLS protocols. This lets the client specify the remote server name -at the start of the SSL handshake, which then lets the server select the right -certificate to complete the process. - -SNI breaks our upstream certificate sniffing process, because when we connect -without using SNI, we get served a default certificate that may have nothing to -do with the certificate expected by the client. The solution is another tricky -complication to the client connection process. After the client connects, we -allow the SSL handshake to continue until just _after_ the SNI value has been -passed to us. Now we can pause the conversation, and initiate an upstream -connection using the correct SNI value, which then serves us the correct -upstream certificate, from which we can extract the expected CN and SANs. - -## Putting it all together - -Lets put all of this together into the complete explicitly proxied HTTPS flow. - -<img class="img-responsive" src="explicit_https.png"/> - -<table class="table"> -    <tbody> -        <tr> -            <td><b>1</b></td> -            <td>The client makes a connection to mitmproxy, and issues an HTTP -            CONNECT request.</td> -        </tr> -        <tr> -            <td><b>2</b></td> - -            <td>Mitmproxy responds with a 200 Connection Established, as if it -            has set up the CONNECT pipe.</td> -        </tr> -        <tr> -            <td><b>3</b></td> - -            <td>The client believes it's talking to the remote server, and -            initiates the SSL connection. It uses SNI to indicate the hostname -            it is connecting to.</td> -        </tr> - -        <tr> -            <td><b>4</b></td> - -            <td>Mitmproxy connects to the server, and establishes an SSL -            connection using the SNI hostname indicated by the client.</td> - -        </tr> -        <tr> -            <td><b>5</b></td> - -            <td>The server responds with the matching SSL certificate, which -            contains the CN and SAN values needed to generate the interception -            certificate.</td> -        </tr> -        <tr> -            <td><b>6</b></td> - -            <td>Mitmproxy generates the interception cert, and continues the -            client SSL handshake paused in step 3.</td> -        </tr> -        <tr> -            <td><b>7</b></td> - -            <td>The client sends the request over the established SSL -            connection.</td> -        </tr> -        <tr> -            <td><b>7</b></td> - -            <td>Mitmproxy passes the request on to the server over the SSL -            connection initiated in step 4.</td> -        </tr> -    </tbody> -</table> - - -<div class="page-header"> -    <h1>Transparent HTTP</h1> -</div> - -When a transparent proxy is used, the HTTP/S connection is redirected into a -proxy at the network layer, without any client configuration being required. -This makes transparent proxying ideal for those situations where you can't -change client behaviour - proxy-oblivious Android applications being a common -example. - -To achieve this, we need to introduce two extra components. The first is a -redirection mechanism that transparently reroutes a TCP connection destined for -a server on the Internet to a listening proxy server. This usually takes the -form of a firewall on the same host as the proxy server - -[iptables](http://www.netfilter.org/) on Linux or -[pf](http://en.wikipedia.org/wiki/PF_\(firewall\)) on OSX. Once the client has -initiated the connection, it makes a vanilla HTTP request, which might look -something like this: - -<pre>GET /index.html HTTP/1.1</pre> - -Note that this request differs from the explicit proxy variation, in that it -omits the scheme and hostname. How, then, do we know which upstream host to -forward the request to? The routing mechanism that has performed the -redirection keeps track of the original destination for us.  Each routing -mechanism has a different way of exposing this data, so this introduces the -second component required for working transparent proxying: a host module that -knows how to retrieve the original destination address from the router. In -mitmproxy, this takes the form of a built-in set of -[modules](https://github.com/mitmproxy/mitmproxy/tree/master/libmproxy/platform) -that know how to talk to each platform's redirection mechanism.  Once we have -this information, the process is fairly straight-forward. - -<img class="img-responsive" src="transparent.png"/> - - -<table class="table"> -    <tbody> -        <tr> -            <td><b>1</b></td> -            <td>The client makes a connection to the server.</td> -        </tr> -        <tr> -            <td><b>2</b></td> - -            <td>The router redirects the connection to mitmproxy, which is -            typically listening on a local port of the same host. Mitmproxy -            then consults the routing mechanism to establish what the original -            destination was.</td> -        </tr> -        <tr> -            <td><b>3</b></td> - -            <td>Now, we simply read the client's request...</td> -        </tr> - -        <tr> -            <td><b>4</b></td> - -            <td>... and forward it upstream.</td> - -        </tr> -    </tbody> -</table> - -<div class="page-header"> -    <h1>Transparent HTTPS</h1> -</div> - -The first step is to determine whether we should treat an incoming connection -as HTTPS. The mechanism for doing this is simple - we use the routing mechanism -to find out what the original destination port is. By default, we treat all -traffic destined for ports 443 and 8443 as SSL. - -From here, the process is a merger of the methods we've described for -transparently proxying HTTP, and explicitly proxying HTTPS. We use the routing -mechanism to establish the upstream server address, and then proceed as for -explicit HTTPS connections to establish the CN and SANs, and cope with SNI. - -<img class="img-responsive" src="transparent_https.png"/> - - -<table class="table"> -    <tbody> -        <tr> -            <td><b>1</b></td> -            <td>The client makes a connection to the server.</td> -        </tr> -        <tr> -            <td><b>2</b></td> - -            <td>The router redirects the connection to mitmproxy, which is -            typically listening on a local port of the same host. Mitmproxy -            then consults the routing mechanism to establish what the original -            destination was.</td> -        </tr> -        <tr> -            <td><b>3</b></td> - -            <td>The client believes it's talking to the remote server, and -            initiates the SSL connection. It uses SNI to indicate the hostname -            it is connecting to.</td> -        </tr> - -        <tr> -            <td><b>4</b></td> - -            <td>Mitmproxy connects to the server, and establishes an SSL -            connection using the SNI hostname indicated by the client.</td> - -        </tr> -        <tr> -            <td><b>5</b></td> - -            <td>The server responds with the matching SSL certificate, which -            contains the CN and SAN values needed to generate the interception -            certificate.</td> -        </tr> -        <tr> -            <td><b>6</b></td> - -            <td>Mitmproxy generates the interception cert, and continues the -            client SSL handshake paused in step 3.</td> -        </tr> -        <tr> -            <td><b>7</b></td> - -            <td>The client sends the request over the established SSL -            connection.</td> -        </tr> -        <tr> -            <td><b>7</b></td> - -            <td>Mitmproxy passes the request on to the server over the SSL -            connection initiated in step 4.</td> -        </tr> -    </tbody> -</table> - - -[^ssl]: I use "SSL" to refer to both SSL and TLS in the generic sense, unless otherwise specified. diff --git a/doc-src/index.html b/doc-src/index.html deleted file mode 100644 index 23da7223..00000000 --- a/doc-src/index.html +++ /dev/null @@ -1,27 +0,0 @@ - -__mitmproxy__ is an interactive, SSL-capable man-in-the-middle proxy for HTTP -with a console interface. - -__mitmdump__ is the command-line version of mitmproxy. Think tcpdump for HTTP. - -__libmproxy__ is the library that mitmproxy and mitmdump are built on. - -Documentation, tutorials and distribution packages can be found on the -mitmproxy.org website: - -[mitmproxy.org](http://mitmproxy.org). - - -Features --------- - -- Intercept HTTP requests and responses and modify them on the fly. -- Save complete HTTP conversations for later replay and analysis. -- Replay the client-side of an HTTP conversations. -- Replay HTTP responses of a previously recorded server. -- Reverse proxy mode to forward traffic to a specified server. -- Transparent proxy mode on OSX and Linux. -- Make scripted changes to HTTP traffic using Python. -- SSL certificates for interception are generated on the fly. -- And much, much more. - diff --git a/doc-src/index.py b/doc-src/index.py deleted file mode 100644 index 2ae9fafe..00000000 --- a/doc-src/index.py +++ /dev/null @@ -1,76 +0,0 @@ -import os -import sys -import datetime -import countershape -from countershape import Page, Directory, markup -import countershape.template - -MITMPROXY_SRC = os.path.abspath( -    os.path.expanduser(os.environ.get("MITMPROXY_SRC", "..")) -) -sys.path.insert(0, MITMPROXY_SRC) -from libmproxy import filt, version - -ns.VERSION = version.VERSION - -if ns.options.website: -    ns.idxpath = "doc/index.html" -else: -    ns.idxpath = "index.html" - -this.layout = countershape.layout.FileLayout("_layout.html") - -ns.title = countershape.template.Template(None, "<h1>@!this.title!@</h1>") -this.titlePrefix = "%s - " % version.NAMEVERSION -this.markup = markup.Markdown(extras=["footnotes"]) - -ns.docMaintainer = "Aldo Cortesi" -ns.docMaintainerEmail = "aldo@corte.si" -ns.copyright = u"\u00a9 mitmproxy project, %s" % datetime.date.today().year - - -def mpath(p): -    p = os.path.join(MITMPROXY_SRC, p) -    return os.path.expanduser(p) - - -def example(s): -    d = file(mpath(s)).read().rstrip() -    extemp = """<div class="example">%s<div class="example_legend">(%s)</div></div>""" -    return extemp % (countershape.template.Syntax("py")(d), s) - - -ns.example = example - - -ns.filt_help = filt.help - - -def nav(page, current, state): -    if current.match(page, False): -        pre = '<li class="active">' -    else: -        pre = "<li>" -    p = state.application.getPage(page) -    return pre + \ -        '<a href="%s">%s</a></li>' % (countershape.widgets.UrlTo(page), p.title) -ns.nav = nav -ns.navbar = countershape.template.File(None, "_nav.html") - - -pages = [ -    Page("index.html", "Introduction"), -    Page("install.html", "Installation"), -    Page("certinstall.html", "About Certificates"), -    Page("howmitmproxy.html", "How mitmproxy works"), -    Page("modes.html", "Modes of Operation"), - -    Page("mitmproxy.html", "mitmproxy"), -    Page("mitmdump.html", "mitmdump"), -    Page("config.html", "configuration"), - -    Directory("scripting"), -    Directory("tutorials"), -    Page("transparent.html", "Overview"), -    Directory("transparent"), -] diff --git a/doc-src/install.html b/doc-src/install.html deleted file mode 100644 index 0afd2bad..00000000 --- a/doc-src/install.html +++ /dev/null @@ -1,79 +0,0 @@ -## On This Page - -* [Installation On Ubuntu](#docUbuntu) -* [Installation On Mac OS X](#docOSX) -* [Installation On Windows](#docWindows) - -## <a id=docUbuntu></a>Installation On Ubuntu - -Ubuntu comes with Python but we need to install pip, python-dev and several libraries.  This was tested on a fully patched installation of Ubuntu 14.04. - -<pre class="terminal"> -$ sudo apt-get install python-pip python-dev libffi-dev libssl-dev libxml2-dev libxslt1-dev - -$ sudo pip install mitmproxy -</pre> - -Once installation is complete you can run <a href="mitmproxy.html">mitmproxy</a> or <a href="mitmdump.html">mitmdump</a> from a terminal. - -### Installation From Source - -If you would like to install mitmproxy directly from the master branch on GitHub or would like to get set up to contribute to the project, -install the dependencies as you would for a regular mitmproxy installation (see previous section). -Then see the <a href="https://github.com/mitmproxy/mitmproxy/blob/master/README.mkd#hacking">Hacking</a> section of the README on GitHub. - - -## <a id=docOSX></a>Installation On Mac OS X - -The easiest way to get up and running on OSX is to download the pre-built binary packages from [mitmproxy.org](http://mitmproxy.org). - -There are a few bits of customization you might want to do to make mitmproxy comfortable to use on OSX. The default color scheme is optimized for a dark background terminal, but you can select a palette for a light terminal background with the --palette option. You can use the OSX <b>open</b> program to create a simple and effective <b>~/.mailcap</b> file to view request and response bodies: - -<pre class="terminal"> -application/*; /usr/bin/open -Wn %s -audio/*; /usr/bin/open -Wn %s -image/*; /usr/bin/open -Wn %s -video/*; /usr/bin/open -Wn %s -</pre> - -Once installation is complete you can run <a href="mitmproxy.html">mitmproxy</a> or <a href="mitmdump.html">mitmdump</a> from a terminal. - -### Installation From Source - -If you would like to install mitmproxy directly from the master branch on GitHub or would like to get set up to contribute to the project, ithere are a few OS X specific things to keep in mind. - -- Make sure that XCode is installed from the App Store, and that the command-line tools have been downloaded (XCode/Preferences/Downloads). -- If you're running a Python interpreter installed with homebrew (or similar), you may have to install some dependencies by hand.  - -Then see the <a href="https://github.com/mitmproxy/mitmproxy/blob/master/README.mkd#hacking">Hacking</a> section of the README on GitHub. - -## <a id=docWindows></a>Installation On Windows - -Please note that mitmdump is the only component of mitmproxy that is supported on Windows at the moment. -There is no interactive user interface on Windows. - - -First, install the latest version of Python 2.7 from the <a href="https://www.python.org/downloads/windows/">Python website</a>. -If you already have an older version of Python 2.7 installed, make sure to install <a href="https://pip.pypa.io/en/latest/installing.html">pip</a> -(pip is included in Python 2.7.9+ by default). - -Next, add Python and the Python Scripts directory to your <strong>PATH</strong> variable. You can do this easily by running the following in powershell: - -<pre class="terminal"> -[Environment]::SetEnvironmentVariable("Path", "$env:Path;C:\Python27\;C:\Python27\Scripts\", "User") -</pre> - - -Now, you can install mitmproxy by running - -<pre class="terminal"> -pip install mitmproxy -</pre> - -Once the installation is complete, you can run <a href="mitmdump.html">mitmdump</a> from a command prompt. - -### Installation From Source - -If you would like to install mitmproxy directly from the master branch on GitHub or would like to get set up to contribute to the project, install Python as outlined above, then see the <a href="https://github.com/mitmproxy/mitmproxy/blob/master/README.mkd#hacking">Hacking</a> section of the README on GitHub. - - diff --git a/doc-src/mitmdump.html b/doc-src/mitmdump.html deleted file mode 100644 index 792f9c52..00000000 --- a/doc-src/mitmdump.html +++ /dev/null @@ -1,68 +0,0 @@ - -__mitmdump__ is the command-line companion to mitmproxy. It provides -tcpdump-like functionality to let you view, record, and programmatically -transform HTTP traffic. See the _--help_ flag output for complete -documentation. - - - -# Examples - - -## Saving traffic - -<pre class="terminal"> -> mitmdump -w outfile -</pre> - -Start up mitmdump in proxy mode, and write all traffic to __outfile__.  - - -## Filtering saved traffic - -<pre class="terminal"> -> mitmdump -nr infile -w outfile "~m post" -</pre> - -Start mitmdump without binding to the proxy port (_-n_), read all flows from -infile, apply the specified filter expression (only match POSTs), and write to -outfile. - - -## Client replay - -<pre class="terminal"> -> mitmdump -nc outfile -</pre> - -Start mitmdump without binding to the proxy port (_-n_), then replay all -requests from outfile (_-c filename_). Flags combine in the obvious way, so -you can replay requests from one file, and write the resulting flows to -another: - -<pre class="terminal"> -> mitmdump -nc srcfile -w dstfile -</pre> - -See the [Client-side Replay](@!urlTo("clientreplay.html")!@) section for more information. - - -## Running a script - -<pre class="terminal"> -> mitmdump -s examples/add_header.py -</pre> - -This runs the __add_header.py__ example script, which simply adds a new header -to all responses. - - -## Scripted data transformation - -<pre class="terminal"> -> mitmdump -ns examples/add_header.py -r srcfile -w dstfile -</pre> - -This command loads flows from __srcfile__, transforms it according to the -specified script, then writes it back to __dstfile__. - diff --git a/doc-src/mitmproxy-long.png b/doc-src/mitmproxy-long.pngBinary files differ deleted file mode 100644 index f9397d1e..00000000 --- a/doc-src/mitmproxy-long.png +++ /dev/null diff --git a/doc-src/mitmproxy.html b/doc-src/mitmproxy.html deleted file mode 100644 index 1ea72295..00000000 --- a/doc-src/mitmproxy.html +++ /dev/null @@ -1,115 +0,0 @@ - -__mitmproxy__ is a console tool that allows interactive examination and -modification of HTTP traffic. It differs from mitmdump in that all flows are -kept in memory, which means that it's intended for taking and manipulating -small-ish samples. Use the _?_ shortcut key to view, context-sensitive -documentation from any __mitmproxy__ screen. - -## Flow list - -The flow list shows an index of captured flows in chronological order. - -<img class="img-responsive" src="@!urlTo('screenshots/mitmproxy.png')!@"/> - -- __1__: A GET request, returning a 302 Redirect response. -- __2__: A GET request, returning 16.75kb of text/html data. -- __3__: A replayed request. -- __4__: Intercepted flows are indicated with orange text. The user may edit -these flows, and then accept them (using the _a_ key) to continue. In this -case, the request has been intercepted on the way to the server. -- __5__: A response intercepted from the server on the way to the client. -- __6__: The event log can be toggled on and off using the _e_ shortcut key. This -pane shows events and errors that may not result in a flow that shows up in the -flow pane. -- __7__: Flow count. -- __8__: Various information on mitmproxy's state. In this case, we have an -interception pattern set to ".*". -- __9__: Bind address indicator - mitmproxy is listening on port 8080 of all -interfaces. - - -## Flow view - -The __Flow View__ lets you inspect and manipulate a single flow: - -<img class="img-responsive" src="@!urlTo('screenshots/mitmproxy-flowview.png')!@"/> - -- __1__: Flow summary. -- __2__: The Request/Response tabs, showing you which part of the flow you are -currently viewing. In the example above, we're viewing the Response. Hit _tab_ -to switch between the Response and the Request. -- __3__: Headers. -- __4__: Body. -- __5__: View Mode indicator. In this case, we're viewing the body in __hex__ -mode. The other available modes are __pretty__, which uses a number of -heuristics to show you a friendly view of various content types, and __raw__, -which shows you exactly what's there without any changes. You can change modes -using the _m_ key. - - - -## Grid Editor - -Much of the data that we'd like to interact with in mitmproxy is structured. -For instance, headers, queries and form data can all be thought of as a list of -key/value pairs. Mitmproxy has a built-in editor that lays this type of data -out in a grid for easy manipulation. - -At the moment, the Grid Editor is used in four parts of mitmproxy: - -- Editing request or response headers (_e_ for edit, then _h_ for headers in flow view) -- Editing a query string (_e_ for edit, then _q_ for query in flow view) -- Editing a URL-encoded form (_e_ for edit, then _f_ for form in flow view) -- Editing replacement patterns (_o_ for options, then _R_ for Replacement Patterns) - -If there is is no data, an empty editor will be started to let you add some. -Here is the editor showing the headers from a request: - -<img class="img-responsive" src="@!urlTo('screenshots/mitmproxy-kveditor.png')!@"/> - -To edit, navigate to the key or value you want to modify using the arrow or vi -navigation keys, and press enter. The background color will change to show that -you are in edit mode for the specified field: - -<img class="img-responsive" src="@!urlTo('screenshots/mitmproxy-kveditor-editmode.png')!@"/> - -Modify the field as desired, then press escape to exit edit mode when you're -done. You can also add a row (_a_ key), delete a row (_d_ key), spawn an -external editor on a field (_e_ key). Be sure to consult the context-sensitive -help (_?_ key) for more. - - -# Example: Interception - -__mitmproxy__'s interception functionality lets you pause an HTTP request or -response, inspect and modify it, and then accept it to send it on to the server -or client. - - -### 1: Set an interception pattern - -<img class="img-responsive" src="@!urlTo('mitmproxy-intercept-filt.png')!@"/> - -We press _i_ to set an interception pattern. In this case, the __~q__ filter -pattern tells __mitmproxy__ to intercept all requests. For complete filter -syntax, see the [Filter expressions](@!urlTo("filters.html")!@) section of this -document, or the built-in help function in __mitmproxy__. - -### 2: Intercepted connections are indicated with orange text: - -<img class="img-responsive" src="@!urlTo('mitmproxy-intercept-mid.png')!@"/> - -### 3: You can now view and modify the request: - -<img class="img-responsive" src="@!urlTo('mitmproxy-intercept-options.png')!@"/> - -In this case, we viewed the request by selecting it, pressed _e_ for "edit" -and _m_ for "method" to change the HTTP request method. - -### 4: Accept the intercept to continue: - -<img class="img-responsive" src="@!urlTo('mitmproxy-intercept-result.png')!@"/> - -Finally, we press _a_ to accept the modified request, which is then sent on to -the server. In this case, we changed the request from an HTTP GET to -OPTIONS, and Google's server has responded with a 405 "Method not allowed". diff --git a/doc-src/modes.html b/doc-src/modes.html deleted file mode 100644 index 6bd92167..00000000 --- a/doc-src/modes.html +++ /dev/null @@ -1,222 +0,0 @@ - -Mitmproxy has four modes of operation that allow you to use mitmproxy in a -variety of scenarios: - -- **Regular** (the default) -- **Transparent** -- **Reverse Proxy** -- **Upstream Proxy** - -Now, which one should you pick? Use this flow chart: - -<img class="img-responsive" src="@!urlTo('schematics/proxy-modes-flowchart.png')!@"/> - -<div class="page-header"> -    <h1>Regular Proxy</h1> -</div> - -Mitmproxy's regular mode is the simplest and the easiest to set up. - -1. Start mitmproxy. -2. Configure your client to use mitmproxy. For instance on IOS, the settings might look like <a href="@!urlTo('screenshots/ios-manual.png')!@">this</a>. -3. Quick Check: You should already be able to visit an unencrypted HTTP site -through the proxy. -4. Open the magic domain <strong>mitm.it</strong> and install the certificate for your device. - -<div class="well"> -<strong>Heads Up:</strong> Unfortunately, some applications bypass the -system HTTP proxy settings - Android applications are a common example. In -these cases, you need to use mitmproxy's transparent mode. -</div> - -If you are proxying an external device, your network will probably look like this: - -<img class="img-responsive" src="@!urlTo('schematics/proxy-modes-regular.png')!@"> - -The square brackets signify the source and destination IP addresses. Your -client explicitly connects to mitmproxy and mitmproxy explicitly connects -to the target server. - -<div class="page-header"> -    <h1>Transparent Proxy</h1> -</div> - -In transparent mode, traffic is directed into a proxy at the network layer, -without any client configuration required. This makes transparent proxying -ideal for situations where you can't change client behaviour. In the graphic -below, a machine running mitmproxy has been inserted between the router and -the internet: - -<a href="@!urlTo('schematics/proxy-modes-transparent-1.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-transparent-1.png')!@"> -</a> - -The square brackets signify the source and destination IP addresses. Round -brackets mark the next hop on the *Ethernet/data link* layer. This distinction -is important: when the packet arrives at the mitmproxy machine, it must still -be addressed to the target server. This means that Network Address Translation -should not be applied before the traffic reaches mitmproxy, since this would -remove the target information, leaving mitmproxy unable to determine the real -destination. - -<a href="@!urlTo('schematics/proxy-modes-transparent-wrong.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-transparent-wrong.png')!@"></a> - -<h2>Common Configurations</h2> - -There are many ways to configure your network for transparent proxying. We'll -look at three common scenarios: - -1. Configuring the client to use a custom gateway/router/"next hop" -2. Implementing custom routing on the router - -In most cases, the first option is recommended due to its ease of use. - -<h3>(a) Custom Gateway</h3> - -One simple way to get traffic to the mitmproxy machine with the destination IP -intact, is to simply configure the client with the mitmproxy box as the -default gateway. - -<a href="@!urlTo('schematics/proxy-modes-transparent-2.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-transparent-2.png')!@"></a> - -In this scenario, we would: - -- Configure the proxy machine for transparent mode. You can find instructions -in the <em>Transparent Proxying</em> section of the mitmproxy docs. - -- Configure the client to use the proxy machine's IP as the default gateway. -<a href="@!urlTo('screenshots/ios-gateway.png')!@">Here</a> is what this would -look like on IOS. - -- Quick Check: At this point, you should already be able to visit an -unencrypted HTTP site over the proxy. - -- Open the magic domain <strong>mitm.it</strong> and install the certificate -for your device. - -Setting the custom gateway on clients can be automated by serving the settings -out to clients over DHCP. This lets set up an interception network where all -clients are proxied automatically, which can save time and effort. - - -<div class="well"> -    <strong style="text-align: center; display: block">Troubleshooting Transparent Mode</strong> - -    <p>Incorrect transparent mode configurations are a frequent source of -    error. If it doesn't work for you, try the following things:</p> - -    <ul> -        <li> -            Open mitmproxy's event log (press `e`) - do you see clientconnect -            messages? If not, the packets are not arriving at the proxy. One common -            cause is the occurrence of ICMP redirects, which means that your -            machine is telling the client that there's a faster way to the -            internet by contacting your router directly (see the -            <em>Transparent Proxying</em> section on how to disable them). If in -            doubt, <a href="https://wireshark.org/">Wireshark</a> may help you -            to see whether something arrives at your machine or not. -        </li> -        <li> -            Make sure you have not explicitly configured an HTTP proxy on the -            client. This is not needed in transparent mode. -        </li> -        <li> -            Re-check the instructions in the <em>Transparent Proxying</em> section. Anything you missed? -        </li> -    </ul> - -    If you encounter any other pitfalls that should be listed here, please let us know! - -</div> - -<h3>(b) Custom Routing</h3> - -In some cases, you may need more fine-grained control of which traffic reaches -the mitmproxy instance, and which doesn't. You may, for instance, choose only -to divert traffic to some hosts into the transparent proxy. There are a huge -number of ways to accomplish this, and much will depend on the router or -packet filter you're using. In most cases, the configuration will look like -this: - -<a href="@!urlTo('schematics/proxy-modes-transparent-3.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-transparent-3.png')!@"> -</a> - - -<div class="page-header"> -    <h1>Reverse Proxy</h1> -</div> - -mitmproxy is usually used with a client that uses the proxy to access the -Internet. Using reverse proxy mode, you can use mitmproxy to act like a normal -HTTP server: - -<a href="@!urlTo('schematics/proxy-modes-reverse.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-reverse.png')!@"> -</a> - -There are various use-cases: - -- Say you have an internal API running at http://example.local/. You could now -set up mitmproxy in reverse proxy mode at http://debug.example.local/ and -dynamically point clients to this new API endpoint, which provides clients -with the same data and you with debug information. Similarly, you could move -your real server to a different IP/port and set up mitmproxy at the original -place to debug all sessions. - -- Say you're a web developer working on example.com (with a development -version running on localhost:8000). You can modify your hosts file so that -example.com points to 127.0.0.1 and then run mitmproxy in reverse proxy mode -on port 80. You can test your app on the example.com domain and get all -requests recorded in mitmproxy. - -- Say you have some toy project that should get SSL support. Simply set up -mitmproxy as a reverse proxy on port 443 and you're done (<code>mitmdump -p 443 -R -http://localhost:80/</code>). mitmproxy auto-detects TLS traffic and intercepts it dynamically. -There are better tools for this specific task, but mitmproxy is very quick and simple way to -set up an SSL-speaking server. - -- Want to add a non-SSL-capable compression proxy in front of your server? You -could even spawn a mitmproxy instance that terminates SSL (-R http://...), -point it to the compression proxy and let the compression proxy point to a -SSL-initiating mitmproxy (-R https://...), which then points to the real -server. As you see, it's a fairly flexible thing. - -Note that mitmproxy supports either an HTTP or an HTTPS upstream server, not -both at the same time. You can work around this by spawning a second mitmproxy -instance. - -<div class="well"> -    <strong style="text-align: center; display: block">Caveat: Interactive Use</strong> - - -One caveat is that reverse proxy mode is often not sufficient for interactive -browsing. Consider trying to clone Google by using: - -<code>mitmproxy -R http://google.com/</code> - -This works for the initial request, but the HTML served to the client remains -unchanged. As soon as the user clicks on an non-relative URL (or downloads a -non-relative image resource), traffic no longer passes through mitmproxy, and -the client connects to Google directly again. - -</div> - - - -<div class="page-header"> -    <h1>Upstream Proxy</h1> -</div> - -If you want to chain proxies by adding mitmproxy in front of a different proxy -appliance, you can use mitmproxy's upstream mode. In upstream mode, all -requests are unconditionally transferred to an upstream proxy of your choice. - -<a href="@!urlTo('schematics/proxy-modes-upstream.png')!@"> -    <img class="img-responsive" src="@!urlTo('schematics/proxy-modes-upstream.png')!@"></a> - -mitmproxy supports both explicit HTTP and explicit HTTPS in upstream proxy -mode. You could in theory chain multiple mitmproxy instances in a row, but -that doesn't make any sense in practice (i.e. outside of our tests). diff --git a/doc-src/schematics/architecture.pdf b/doc-src/schematics/architecture.pdfBinary files differ deleted file mode 100644 index 77f5ad58..00000000 --- a/doc-src/schematics/architecture.pdf +++ /dev/null diff --git a/doc-src/schematics/architecture.png b/doc-src/schematics/architecture.pngBinary files differ deleted file mode 100644 index 67d6c718..00000000 --- a/doc-src/schematics/architecture.png +++ /dev/null diff --git a/doc-src/schematics/architecture.vsdx b/doc-src/schematics/architecture.vsdxBinary files differ deleted file mode 100644 index c4ff13d2..00000000 --- a/doc-src/schematics/architecture.vsdx +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-flowchart.png b/doc-src/schematics/proxy-modes-flowchart.pngBinary files differ deleted file mode 100644 index 716b5ee2..00000000 --- a/doc-src/schematics/proxy-modes-flowchart.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-regular.png b/doc-src/schematics/proxy-modes-regular.pngBinary files differ deleted file mode 100644 index 95bada08..00000000 --- a/doc-src/schematics/proxy-modes-regular.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-reverse.png b/doc-src/schematics/proxy-modes-reverse.pngBinary files differ deleted file mode 100644 index 071d3fc8..00000000 --- a/doc-src/schematics/proxy-modes-reverse.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-transparent-1.png b/doc-src/schematics/proxy-modes-transparent-1.pngBinary files differ deleted file mode 100644 index 002e0e76..00000000 --- a/doc-src/schematics/proxy-modes-transparent-1.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-transparent-2.png b/doc-src/schematics/proxy-modes-transparent-2.pngBinary files differ deleted file mode 100644 index 41997b05..00000000 --- a/doc-src/schematics/proxy-modes-transparent-2.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-transparent-3.png b/doc-src/schematics/proxy-modes-transparent-3.pngBinary files differ deleted file mode 100644 index ee26cb4f..00000000 --- a/doc-src/schematics/proxy-modes-transparent-3.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-transparent-wrong.png b/doc-src/schematics/proxy-modes-transparent-wrong.pngBinary files differ deleted file mode 100644 index ca501e93..00000000 --- a/doc-src/schematics/proxy-modes-transparent-wrong.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes-upstream.png b/doc-src/schematics/proxy-modes-upstream.pngBinary files differ deleted file mode 100644 index d40a6494..00000000 --- a/doc-src/schematics/proxy-modes-upstream.png +++ /dev/null diff --git a/doc-src/schematics/proxy-modes.pdf b/doc-src/schematics/proxy-modes.pdfBinary files differ deleted file mode 100644 index f07ea05e..00000000 --- a/doc-src/schematics/proxy-modes.pdf +++ /dev/null diff --git a/doc-src/schematics/proxy-modes.vsdx b/doc-src/schematics/proxy-modes.vsdxBinary files differ deleted file mode 100644 index c78cf8d0..00000000 --- a/doc-src/schematics/proxy-modes.vsdx +++ /dev/null diff --git a/doc-src/screenshots/firefox3-import.jpg b/doc-src/screenshots/firefox3-import.jpgBinary files differ deleted file mode 100644 index 47fcd672..00000000 --- a/doc-src/screenshots/firefox3-import.jpg +++ /dev/null diff --git a/doc-src/screenshots/firefox3-trust.jpg b/doc-src/screenshots/firefox3-trust.jpgBinary files differ deleted file mode 100644 index 50a2f341..00000000 --- a/doc-src/screenshots/firefox3-trust.jpg +++ /dev/null diff --git a/doc-src/screenshots/firefox3.jpg b/doc-src/screenshots/firefox3.jpgBinary files differ deleted file mode 100644 index 6c4613b6..00000000 --- a/doc-src/screenshots/firefox3.jpg +++ /dev/null diff --git a/doc-src/screenshots/ios-gateway.png b/doc-src/screenshots/ios-gateway.pngBinary files differ deleted file mode 100644 index 2489cba3..00000000 --- a/doc-src/screenshots/ios-gateway.png +++ /dev/null diff --git a/doc-src/screenshots/ios-installed.png b/doc-src/screenshots/ios-installed.pngBinary files differ deleted file mode 100644 index 2071e441..00000000 --- a/doc-src/screenshots/ios-installed.png +++ /dev/null diff --git a/doc-src/screenshots/ios-manual.png b/doc-src/screenshots/ios-manual.pngBinary files differ deleted file mode 100644 index 3977acfe..00000000 --- a/doc-src/screenshots/ios-manual.png +++ /dev/null diff --git a/doc-src/screenshots/ios-profile.png b/doc-src/screenshots/ios-profile.pngBinary files differ deleted file mode 100644 index 5bcd5a0d..00000000 --- a/doc-src/screenshots/ios-profile.png +++ /dev/null diff --git a/doc-src/screenshots/ios-reverse.png b/doc-src/screenshots/ios-reverse.pngBinary files differ deleted file mode 100644 index 6ab5b7c0..00000000 --- a/doc-src/screenshots/ios-reverse.png +++ /dev/null diff --git a/doc-src/screenshots/ios-warning.png b/doc-src/screenshots/ios-warning.pngBinary files differ deleted file mode 100644 index d882c514..00000000 --- a/doc-src/screenshots/ios-warning.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-flowview.png b/doc-src/screenshots/mitmproxy-flowview.pngBinary files differ deleted file mode 100644 index 154963fe..00000000 --- a/doc-src/screenshots/mitmproxy-flowview.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-intercept-filt.png b/doc-src/screenshots/mitmproxy-intercept-filt.pngBinary files differ deleted file mode 100644 index 60556ee7..00000000 --- a/doc-src/screenshots/mitmproxy-intercept-filt.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-intercept-mid.png b/doc-src/screenshots/mitmproxy-intercept-mid.pngBinary files differ deleted file mode 100644 index d5b03922..00000000 --- a/doc-src/screenshots/mitmproxy-intercept-mid.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-intercept-options.png b/doc-src/screenshots/mitmproxy-intercept-options.pngBinary files differ deleted file mode 100644 index 8dc4ad2c..00000000 --- a/doc-src/screenshots/mitmproxy-intercept-options.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-intercept-result.png b/doc-src/screenshots/mitmproxy-intercept-result.pngBinary files differ deleted file mode 100644 index 7d9f5c94..00000000 --- a/doc-src/screenshots/mitmproxy-intercept-result.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-kveditor-editmode.png b/doc-src/screenshots/mitmproxy-kveditor-editmode.pngBinary files differ deleted file mode 100644 index a8315ee5..00000000 --- a/doc-src/screenshots/mitmproxy-kveditor-editmode.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy-kveditor.png b/doc-src/screenshots/mitmproxy-kveditor.pngBinary files differ deleted file mode 100644 index 144b9701..00000000 --- a/doc-src/screenshots/mitmproxy-kveditor.png +++ /dev/null diff --git a/doc-src/screenshots/mitmproxy.png b/doc-src/screenshots/mitmproxy.pngBinary files differ deleted file mode 100644 index 42a10e32..00000000 --- a/doc-src/screenshots/mitmproxy.png +++ /dev/null diff --git a/doc-src/screenshots/osx-addcert-alwaystrust.png b/doc-src/screenshots/osx-addcert-alwaystrust.pngBinary files differ deleted file mode 100644 index 4c5cc704..00000000 --- a/doc-src/screenshots/osx-addcert-alwaystrust.png +++ /dev/null diff --git a/doc-src/screenshots/win7-certstore-trustedroot.png b/doc-src/screenshots/win7-certstore-trustedroot.pngBinary files differ deleted file mode 100644 index e15a87f5..00000000 --- a/doc-src/screenshots/win7-certstore-trustedroot.png +++ /dev/null diff --git a/doc-src/screenshots/win7-certstore.png b/doc-src/screenshots/win7-certstore.pngBinary files differ deleted file mode 100644 index f8ce54bd..00000000 --- a/doc-src/screenshots/win7-certstore.png +++ /dev/null diff --git a/doc-src/screenshots/win7-wizard.png b/doc-src/screenshots/win7-wizard.pngBinary files differ deleted file mode 100644 index eff6ad09..00000000 --- a/doc-src/screenshots/win7-wizard.png +++ /dev/null diff --git a/doc-src/screenshots/winpythoninstaller.jpg b/doc-src/screenshots/winpythoninstaller.jpgBinary files differ deleted file mode 100644 index 0473c66a..00000000 --- a/doc-src/screenshots/winpythoninstaller.jpg +++ /dev/null diff --git a/doc-src/scripting/index.py b/doc-src/scripting/index.py deleted file mode 100644 index b8312083..00000000 --- a/doc-src/scripting/index.py +++ /dev/null @@ -1,6 +0,0 @@ -from countershape import Page - -pages = [ -    Page("inlinescripts.html", "Inline Scripts"), -    Page("libmproxy.html", "libmproxy"), -] diff --git a/doc-src/scripting/inlinescripts.html b/doc-src/scripting/inlinescripts.html deleted file mode 100644 index 7cd6af25..00000000 --- a/doc-src/scripting/inlinescripts.html +++ /dev/null @@ -1,177 +0,0 @@ -__mitmproxy__ has a powerful scripting API that allows you to modify flows -on-the-fly or rewrite previously saved flows locally. - -The mitmproxy scripting API is event driven - a script is simply a Python -module that exposes a set of event methods. Here's a complete mitmproxy script -that adds a new header to every HTTP response before it is returned to the -client: - -$!example("examples/add_header.py")!$ - -The first argument to each event method is an instance of ScriptContext that -lets the script interact with the global mitmproxy state. The __response__ -event also gets an instance of Flow, which we can use to manipulate the -response itself. - -We can now run this script using mitmdump or mitmproxy as follows: - -<pre class="terminal"> -> mitmdump -s add_header.py -</pre> - -The new header will be added to all responses passing through the proxy. - -## Example Scripts - -mitmproxy comes with a variety of example inline scripts, which demonstrate -many basic tasks. We encourage you to either browse them locally or in our -[GitHub repo](https://github.com/mitmproxy/mitmproxy/tree/master/examples). - - -## Events - -### start(ScriptContext, argv) - -Called once on startup, before any other events. - - -### clientconnect(ScriptContext, ConnectionHandler) - -Called when a client initiates a connection to the proxy. Note that -a connection can correspond to multiple HTTP requests. - -### serverconnect(ScriptContext, ConnectionHandler) - -Called when the proxy initiates a connection to the target server. Note that -a connection can correspond to multiple HTTP requests. - -### request(ScriptContext, HTTPFlow) - -Called when a client request has been received. The __HTTPFlow__ object is -guaranteed to have a non-None __request__ attribute. - -### responseheaders(ScriptContext, HTTPFlow) - -Called when the headers of a server response have been received. -This will always be called before the response hook. -The __HTTPFlow__ object is guaranteed to have non-None __request__ and -__response__ attributes.  __response.content__ will be None, -as the response body has not been read yet. - -### response(ScriptContext, HTTPFlow) - -Called when a server response has been received. The __HTTPFlow__ object is -guaranteed to have non-None __request__ and __response__ attributes. -Note that if response streaming is enabled for this response, -__response.content__ will not contain the response body. - -### error(ScriptContext, HTTPFlow) - -Called when a flow error has occurred, e.g. invalid server responses, or -interrupted connections. This is distinct from a valid server HTTP error -response, which is simply a response with an HTTP error code. The __HTTPFlow__ -object is guaranteed to have non-None __request__ and __error__ attributes. - - -### clientdisconnect(ScriptContext, ConnectionHandler) - -Called when a client disconnects from the proxy. - -### done(ScriptContext) - -Called once on script shutdown, after any other events. - - -## API - -The main classes you will deal with in writing mitmproxy scripts are: - -<table class="table"> -    <tr> -        <th>libmproxy.proxy.server.ConnectionHandler</th> -        <td>Describes a proxy client connection session. Always has a client_conn attribute, might have a server_conn -            attribute. -        </td> -    </tr> -    <tr> -        <th>libmproxy.proxy.connection.ClientConnection</th> -        <td>Describes a client connection.</td> -    </tr> -    <tr> -        <th>libmproxy.proxy.connection.ServerConnection</th> -        <td>Describes a server connection.</td> -    </tr> -    <tr> -        <th>libmproxy.protocol.http.HTTPFlow</th> -        <td>A collection of objects representing a single HTTP transaction.</td> -    </tr> -    <tr> -        <th>libmproxy.protocol.http.HTTPResponse</th> -        <td>An HTTP response.</td> -    </tr> -    <tr> -        <th>libmproxy.protocol.http.HTTPRequest</th> -        <td>An HTTP request.</td> -    </tr> -    <tr> -        <th>libmproxy.protocol.primitives.Error</th> -        <td>A communications error.</td> -    </tr> -    <tr> -        <th>libmproxy.script.ScriptContext</th> -        <td> A handle for interacting with mitmproxy's from within scripts.</td> -    </tr> -    <tr> -        <th>netlib.odict.ODict</th> - -        <td>A dictionary-like object for managing sets of key/value data. There -        is also a variant called ODictCaseless that ignores key case for some -        calls (used mainly for headers).</td> -    </tr> -    <tr> -        <th>netlib.certutils.SSLCert</th> -        <td>Exposes information SSL certificates.</td> -    </tr> -</table> - -The canonical API documentation is the code, which you can browse locally or in our -[GitHub repo](https://github.com/mitmproxy/mitmproxy). -You can view the API documentation using pydoc (which is installed with Python by default), like this: - -<pre class="terminal"> -> pydoc libmproxy.protocol.http.HTTPRequest -</pre> - - -## Running scripts in parallel - -We have a single flow primitive, so when a script is blocking, other requests are not processed. -While that's usually a very desirable behaviour, blocking scripts can be run threaded by using the <code>libmproxy.script.concurrent</code> decorator. -If your script does not block, you should avoid the overhead of the decorator. - -$!example("examples/nonblocking.py")!$ - -## Make scripts configurable with arguments - -Sometimes, you want to pass runtime arguments to the inline script. This can be simply done by surrounding the script call with quotes, e.g. -<code>mitmdump -s "script.py --foo 42"</code>. The arguments are then exposed in the start event: - -$!example("examples/modify_response_body.py")!$ - -## Running scripts on saved flows - -Sometimes, we want to run a script on __Flow__ objects that are already -complete.  This happens when you start a script, and then load a saved set of -flows from a file (see the "scripted data transformation" example on the -[mitmdump](@!urlTo("mitmdump.html")!@) page). It also happens when you run a -one-shot script on a single flow through the _|_ (pipe) shortcut in mitmproxy. - -In this case, there are no client connections, and the events are run in the -following order: __start__, __request__, __responseheaders__, __response__, __error__, __done__.  If -the flow doesn't have a __response__ or __error__ associated with it, the -matching events will be skipped. - -## Spaces in the script path -By default, spaces are interpreted as separator between the inline script and its arguments (e.g. <code>-s "foo.py -    42"</code>). Consequently, the script path needs to be wrapped in a separate pair of quotes if it contains spaces: -<code>-s "'./foo bar/baz.py' 42"</code>. diff --git a/doc-src/scripting/libmproxy.html b/doc-src/scripting/libmproxy.html deleted file mode 100644 index db58f7e0..00000000 --- a/doc-src/scripting/libmproxy.html +++ /dev/null @@ -1,22 +0,0 @@ -<div class="well"> -    <strong>Heads up!</strong> We strongly encourage you to use <a href="@!urlTo("scripting/inlinescripts.html")!@">inline scripts</a> rather than libmproxy -    directly.<br><br> -    <ul> -        <li>Inline Scripts are equally powerful and provide an easier syntax.</li> -        <li>Most examples are written as inline scripts.</li> -        <li>Multiple inline scripts can be combined and used together.</li> -        <li>Inline Scripts can either be executed headless with mitmdump or within the mitmproxy UI.</li> -    </ul> -</div> - -All of mitmproxy's basic functionality is exposed through the __libmproxy__ -library. The example below shows a simple implementation of the "sticky cookie" -functionality included in the interactive mitmproxy program. Traffic is -monitored for __cookie__ and __set-cookie__ headers, and requests are rewritten -to include a previously seen cookie if they don't already have one. In effect, -this lets you log in to a site using your browser, and then make subsequent -requests using a tool like __curl__, which will then seem to be part of the -authenticated session. - -$!example("examples/stickycookies")!$ - diff --git a/doc-src/syntax.css b/doc-src/syntax.css deleted file mode 100644 index e371658a..00000000 --- a/doc-src/syntax.css +++ /dev/null @@ -1,120 +0,0 @@ -.highlight  { background: #f8f8f8; } -.highlight .c { color: #408080; font-style: italic } /* Comment */ -.highlight .err { border: 1px solid #FF0000 } /* Error */ -.highlight .k { color: #008000; font-weight: bold } /* Keyword */ -.highlight .o { color: #666666 } /* Operator */ -.highlight .cm { color: #408080; font-style: italic } /* Comment.Multiline */ -.highlight .cp { color: #BC7A00 } /* Comment.Preproc */ -.highlight .c1 { color: #408080; font-style: italic } /* Comment.Single */ -.highlight .cs { color: #408080; font-style: italic } /* Comment.Special */ -.highlight .gd { color: #A00000 } /* Generic.Deleted */ -.highlight .ge { font-style: italic } /* Generic.Emph */ -.highlight .gr { color: #FF0000 } /* Generic.Error */ -.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */ -.highlight .gi { color: #00A000 } /* Generic.Inserted */ -.highlight .go { color: #808080 } /* Generic.Output */ -.highlight .gp { color: #000080; font-weight: bold } /* Generic.Prompt */ -.highlight .gs { font-weight: bold } /* Generic.Strong */ -.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ -.highlight .gt { color: #0040D0 } /* Generic.Traceback */ -.highlight .kc { color: #008000; font-weight: bold } /* Keyword.Constant */ -.highlight .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ -.highlight .kp { color: #008000 } /* Keyword.Pseudo */ -.highlight .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ -.highlight .kt { color: #B00040 } /* Keyword.Type */ -.highlight .m { color: #666666 } /* Literal.Number */ -.highlight .s { color: #BA2121 } /* Literal.String */ -.highlight .na { color: #7D9029 } /* Name.Attribute */ -.highlight .nb { color: #008000 } /* Name.Builtin */ -.highlight .nc { color: #0000FF; font-weight: bold } /* Name.Class */ -.highlight .no { color: #880000 } /* Name.Constant */ -.highlight .nd { color: #AA22FF } /* Name.Decorator */ -.highlight .ni { color: #999999; font-weight: bold } /* Name.Entity */ -.highlight .ne { color: #D2413A; font-weight: bold } /* Name.Exception */ -.highlight .nf { color: #0000FF } /* Name.Function */ -.highlight .nl { color: #A0A000 } /* Name.Label */ -.highlight .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ -.highlight .nt { color: #008000; font-weight: bold } /* Name.Tag */ -.highlight .nv { color: #19177C } /* Name.Variable */ -.highlight .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ -.highlight .w { color: #bbbbbb } /* Text.Whitespace */ -.highlight .mf { color: #666666 } /* Literal.Number.Float */ -.highlight .mh { color: #666666 } /* Literal.Number.Hex */ -.highlight .mi { color: #666666 } /* Literal.Number.Integer */ -.highlight .mo { color: #666666 } /* Literal.Number.Oct */ -.highlight .sb { color: #BA2121 } /* Literal.String.Backtick */ -.highlight .sc { color: #BA2121 } /* Literal.String.Char */ -.highlight .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ -.highlight .s2 { color: #BA2121 } /* Literal.String.Double */ -.highlight .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */ -.highlight .sh { color: #BA2121 } /* Literal.String.Heredoc */ -.highlight .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */ -.highlight .sx { color: #008000 } /* Literal.String.Other */ -.highlight .sr { color: #BB6688 } /* Literal.String.Regex */ -.highlight .s1 { color: #BA2121 } /* Literal.String.Single */ -.highlight .ss { color: #19177C } /* Literal.String.Symbol */ -.highlight .bp { color: #008000 } /* Name.Builtin.Pseudo */ -.highlight .vc { color: #19177C } /* Name.Variable.Class */ -.highlight .vg { color: #19177C } /* Name.Variable.Global */ -.highlight .vi { color: #19177C } /* Name.Variable.Instance */ -.highlight .il { color: #666666 } /* Literal.Number.Integer.Long */ -.grokdoc  { background: #f8f8f8; } -.grokdoc .c { color: #408080; font-style: italic } /* Comment */ -.grokdoc .err { border: 1px solid #FF0000 } /* Error */ -.grokdoc .k { color: #008000; font-weight: bold } /* Keyword */ -.grokdoc .o { color: #666666 } /* Operator */ -.grokdoc .cm { color: #408080; font-style: italic } /* Comment.Multiline */ -.grokdoc .cp { color: #BC7A00 } /* Comment.Preproc */ -.grokdoc .c1 { color: #408080; font-style: italic } /* Comment.Single */ -.grokdoc .cs { color: #408080; font-style: italic } /* Comment.Special */ -.grokdoc .gd { color: #A00000 } /* Generic.Deleted */ -.grokdoc .ge { font-style: italic } /* Generic.Emph */ -.grokdoc .gr { color: #FF0000 } /* Generic.Error */ -.grokdoc .gh { color: #000080; font-weight: bold } /* Generic.Heading */ -.grokdoc .gi { color: #00A000 } /* Generic.Inserted */ -.grokdoc .go { color: #808080 } /* Generic.Output */ -.grokdoc .gp { color: #000080; font-weight: bold } /* Generic.Prompt */ -.grokdoc .gs { font-weight: bold } /* Generic.Strong */ -.grokdoc .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ -.grokdoc .gt { color: #0040D0 } /* Generic.Traceback */ -.grokdoc .kc { color: #008000; font-weight: bold } /* Keyword.Constant */ -.grokdoc .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ -.grokdoc .kp { color: #008000 } /* Keyword.Pseudo */ -.grokdoc .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ -.grokdoc .kt { color: #B00040 } /* Keyword.Type */ -.grokdoc .m { color: #666666 } /* Literal.Number */ -.grokdoc .s { color: #BA2121 } /* Literal.String */ -.grokdoc .na { color: #7D9029 } /* Name.Attribute */ -.grokdoc .nb { color: #008000 } /* Name.Builtin */ -.grokdoc .nc { color: #0000FF; font-weight: bold } /* Name.Class */ -.grokdoc .no { color: #880000 } /* Name.Constant */ -.grokdoc .nd { color: #AA22FF } /* Name.Decorator */ -.grokdoc .ni { color: #999999; font-weight: bold } /* Name.Entity */ -.grokdoc .ne { color: #D2413A; font-weight: bold } /* Name.Exception */ -.grokdoc .nf { color: #0000FF } /* Name.Function */ -.grokdoc .nl { color: #A0A000 } /* Name.Label */ -.grokdoc .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ -.grokdoc .nt { color: #008000; font-weight: bold } /* Name.Tag */ -.grokdoc .nv { color: #19177C } /* Name.Variable */ -.grokdoc .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ -.grokdoc .w { color: #bbbbbb } /* Text.Whitespace */ -.grokdoc .mf { color: #666666 } /* Literal.Number.Float */ -.grokdoc .mh { color: #666666 } /* Literal.Number.Hex */ -.grokdoc .mi { color: #666666 } /* Literal.Number.Integer */ -.grokdoc .mo { color: #666666 } /* Literal.Number.Oct */ -.grokdoc .sb { color: #BA2121 } /* Literal.String.Backtick */ -.grokdoc .sc { color: #BA2121 } /* Literal.String.Char */ -.grokdoc .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ -.grokdoc .s2 { color: #BA2121 } /* Literal.String.Double */ -.grokdoc .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */ -.grokdoc .sh { color: #BA2121 } /* Literal.String.Heredoc */ -.grokdoc .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */ -.grokdoc .sx { color: #008000 } /* Literal.String.Other */ -.grokdoc .sr { color: #BB6688 } /* Literal.String.Regex */ -.grokdoc .s1 { color: #BA2121 } /* Literal.String.Single */ -.grokdoc .ss { color: #19177C } /* Literal.String.Symbol */ -.grokdoc .bp { color: #008000 } /* Name.Builtin.Pseudo */ -.grokdoc .vc { color: #19177C } /* Name.Variable.Class */ -.grokdoc .vg { color: #19177C } /* Name.Variable.Global */ -.grokdoc .vi { color: #19177C } /* Name.Variable.Instance */ -.grokdoc .il { color: #666666 } /* Literal.Number.Integer.Long */ diff --git a/doc-src/transparent.html b/doc-src/transparent.html deleted file mode 100644 index 4e9b6774..00000000 --- a/doc-src/transparent.html +++ /dev/null @@ -1,19 +0,0 @@ - -When a transparent proxy is used, traffic is redirected into a proxy at the -network layer, without any client configuration being required. This makes -transparent proxying ideal for those situations where you can't change client -behaviour - proxy-oblivious Android applications being a common example. - -To set up transparent proxying, we need two new components. The first is a -redirection mechanism that transparently reroutes a TCP connection destined for -a server on the Internet to a listening proxy server. This usually takes the -form of a firewall on the same host as the proxy server - -[iptables](http://www.netfilter.org/) on Linux or -[pf](http://en.wikipedia.org/wiki/PF_\(firewall\)) on OSX. When the proxy -receives a redirected connection, it sees a vanilla HTTP request, without a -host specification. This is where the second new component comes in - a host -module that allows us to query the redirector for the original destination of -the TCP connection. - -At the moment, mitmproxy supports transparent proxying on OSX Lion and above, -and all current flavors of Linux. diff --git a/doc-src/transparent.png b/doc-src/transparent.pngBinary files differ deleted file mode 100644 index 3994d681..00000000 --- a/doc-src/transparent.png +++ /dev/null diff --git a/doc-src/transparent/index.py b/doc-src/transparent/index.py deleted file mode 100644 index 091b3471..00000000 --- a/doc-src/transparent/index.py +++ /dev/null @@ -1,6 +0,0 @@ -from countershape import Page - -pages = [ -    Page("osx.html", "OSX"), -    Page("linux.html", "Linux"), -] diff --git a/doc-src/transparent/linux.html b/doc-src/transparent/linux.html deleted file mode 100644 index d4b490c7..00000000 --- a/doc-src/transparent/linux.html +++ /dev/null @@ -1,53 +0,0 @@ -On Linux, mitmproxy integrates with the iptables redirection mechanism to -achieve transparent mode. - -<ol class="tlist"> - -    <li> <a href="@!urlTo('certinstall.html')!@">Install the mitmproxy -    certificates on the test device</a>. </li> - -    <li> Enable IP forwarding: - -    <pre class="terminal">sysctl -w net.ipv4.ip_forward=1</pre> - -    You may also want to consider enabling this permanently in -    <b>/etc/sysctl.conf</b>. - -    </li> - -    <li> If your target machine is on the same physical network and you configured it to use a custom gateway, -    disable ICMP redirects: - -    <pre class="terminal">echo 0 | sudo tee /proc/sys/net/ipv4/conf/*/send_redirects</pre> - -    You may also want to consider enabling this permanently in -    <b>/etc/sysctl.conf</b> as demonstrated <a href="http://unix.stackexchange.com/a/58081">here</a>. - -    </li> - -    <li> Create an iptables ruleset that redirects the desired traffic to the -    mitmproxy port. Details will differ according to your setup, but the -    ruleset should look something like this: - -<pre class="terminal">iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 8080 -iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 443 -j REDIRECT --to-port 8080</pre> - -    </li> - -    <li> Fire up mitmproxy. You probably want a command like this: - -        <pre class="terminal">mitmproxy -T --host</pre> - -        The <b>-T</b> flag turns on transparent mode, and the <b>--host</b> -        argument tells mitmproxy to use the value of the Host header for URL -        display. - -    </li> - -    <li> Finally, configure your test device to use the host on which mitmproxy is -    running as the default gateway.</li> - -</ol> - - -For a detailed walkthrough, have a look at the <a href="@!urlTo('tutorials/transparent-dhcp.html')!@"><i>Transparently proxify virtual machines</i></a> tutorial. diff --git a/doc-src/transparent/osx.html b/doc-src/transparent/osx.html deleted file mode 100644 index c8eb6c4e..00000000 --- a/doc-src/transparent/osx.html +++ /dev/null @@ -1,78 +0,0 @@ - - -OSX Lion integrated the [pf](http://www.openbsd.org/faq/pf/) packet filter from -the OpenBSD project, which mitmproxy uses to implement transparent mode on OSX. -Note that this means we don't support transparent mode for earlier versions of -OSX. - -<ol class="tlist"> - -    <li> <a href="@!urlTo('certinstall.html')!@">Install the mitmproxy -    certificates on the test device</a>. </li> - -    <li> Enable IP forwarding: - -    <pre class="terminal">sudo sysctl -w net.inet.ip.forwarding=1</pre> -    </li> - -    <li>  Place the following two lines in a file called, say, <b>pf.conf</b>: - -<pre class="terminal">rdr on en2 inet proto tcp to any port 80 -> 127.0.0.1 port 8080 -rdr on en2 inet proto tcp to any port 443 -> 127.0.0.1 port 8080 -</pre> - -        These rules tell pf to redirect all traffic destined for port 80 or 443 -        to the local mitmproxy instance running on port 8080. You should -        replace <b>en2</b> with the interface on which your test device will -        appear. - -    </li> - -    <li> Configure pf with the rules: - -        <pre class="terminal">sudo pfctl -f pf.conf</pre> - -    </li> - -    <li> And now enable it: - -        <pre class="terminal">sudo pfctl -e</pre> - -    </li> - -    <li> Configure sudoers to allow mitmproxy to access pfctl. Edit the file -    <b>/etc/sudoers</b> on your system as root. Add the following line to the end -    of the file: - -    <pre>ALL ALL=NOPASSWD: /sbin/pfctl -s state</pre> - -    Note that this allows any user on the system to run the command -    "/sbin/pfctl -s state" as root without a password. This only allows -    inspection of the state table, so should not be an undue security risk. If -    you're special feel free to tighten the restriction up to the user running -    mitmproxy.</li> - -    <li> Fire up mitmproxy. You probably want a command like this: - -        <pre class="terminal">mitmproxy -T --host</pre> - -        The <b>-T</b> flag turns on transparent mode, and the <b>--host</b> -        argument tells mitmproxy to use the value of the Host header for URL -        display. - -    </li> - -    <li> Finally, configure your test device to use the host on which mitmproxy is -    running as the default gateway.</li> - - -</ol> - -Note that the **rdr** rules in the pf.conf given above only apply to inbound -traffic. This means that they will NOT redirect traffic coming from the box -running pf itself. We can't distinguish between an outbound connection from a -non-mitmproxy app, and an outbound connection from mitmproxy itself - if you -want to intercept your OSX traffic, you should use an external host to run -mitmproxy. None the less, pf is flexible to cater for a range of creative -possibilities, like intercepting traffic emanating from VMs.  See the -**pf.conf** man page for more. diff --git a/doc-src/transparent_https.png b/doc-src/transparent_https.pngBinary files differ deleted file mode 100644 index 559cddd2..00000000 --- a/doc-src/transparent_https.png +++ /dev/null diff --git a/doc-src/tutorials/30second.html b/doc-src/tutorials/30second.html deleted file mode 100644 index fe9581c5..00000000 --- a/doc-src/tutorials/30second.html +++ /dev/null @@ -1,61 +0,0 @@ - -My local cafe is serviced by a rickety and unreliable wireless network, -generously sponsored with ratepayers' money by our city council. After -connecting, you  are redirected to an SSL-protected page that prompts you for a -username and password. Once you've entered your details, you are free to enjoy -the intermittent dropouts, treacle-like speeds and incorrectly configured -transparent proxy.  - -I tend to automate this kind of thing at the first opportunity, on the theory -that time spent now will be more than made up in the long run. In this case, I -might use [Firebug](http://getfirebug.com/) to ferret out the form post -parameters and target URL, then fire up an editor to write a little script -using Python's [urllib](http://docs.python.org/library/urllib.html) to simulate -a submission. That's a lot of futzing about. With mitmproxy we can do the job -in literally 30 seconds, without having to worry about any of the details. -Here's how. - -## 1. Run mitmdump to record our HTTP conversation to a file. - -<pre class="terminal"> -> mitmdump -w wireless-login -</pre> - -## 2. Point your browser at the mitmdump instance.  - -I use a tiny Firefox addon called [Toggle -Proxy](https://addons.mozilla.org/en-us/firefox/addon/toggle-proxy-51740/) to -switch quickly to and from mitmproxy. I'm assuming you've already [configured -your browser with mitmproxy's SSL certificate -authority](http://mitmproxy.org/doc/ssl.html). - -## 3. Log in as usual.  - - -And that's it! You now have a serialized version of the login process in the -file wireless-login, and you can replay it at any time like this: - -<pre class="terminal"> -> mitmdump -c wireless-login -</pre> - -## Embellishments - -We're really done at this point, but there are a couple of embellishments we -could make if we wanted. I use [wicd](http://wicd.sourceforge.net/) to -automatically join wireless networks I frequent, and it lets me specify a -command to run after connecting. I used the client replay command above and -voila! - totally hands-free wireless network startup. - -We might also want to prune requests that download CSS, JS, images and so -forth. These add only a few moments to the time it takes to replay, but they're -not really needed and I somehow feel compelled to trim them anyway. So, we fire up -the mitmproxy console tool on our serialized conversation, like so: - -<pre class="terminal"> -> mitmproxy -r wireless-login -</pre> - -We can now go through and manually delete (using the __d__ keyboard shortcut) -everything we want to trim. When we're done, we use __w__ to save the -conversation back to the file. diff --git a/doc-src/tutorials/gamecenter.html b/doc-src/tutorials/gamecenter.html deleted file mode 100644 index af11b5bb..00000000 --- a/doc-src/tutorials/gamecenter.html +++ /dev/null @@ -1,119 +0,0 @@ - -## The setup - -In this tutorial, I'm going to show you how simple it is to creatively -interfere with Apple Game Center traffic using mitmproxy. To set things up, -install the [mitmproxy root certificate](@!urlTo("certinstall.html")!@). Then -start mitmproxy on your desktop, and confige the iPhone to use it as a proxy. - - -## Taking a look at the Game Center traffic - -Lets take a first look at the Game Center traffic. The game I'll use in this -tutorial is [Super Mega -Worm](http://itunes.apple.com/us/app/super-mega-worm/id388541990?mt=8) - a -great little retro-apocalyptic sidescroller for the iPhone: - -<center> -    <img class="img-responsive" src="@!urlTo('tutorials/supermega.png')!@"/> -</center> - -After finishing a game (take your time), watch the traffic flowing through -mitmproxy: - -<center> -    <img class="img-responsive" src="@!urlTo('tutorials/one.png')!@"/> -</center> - -We see a bunch of things we might expect - initialisation, the retrieval of -leaderboards and so forth. Then, right at the end, there's a POST to this -tantalising URL: - -<pre> -https://service.gc.apple.com/WebObjects/GKGameStatsService.woa/wa/submitScore -</pre> - -The contents of the submission are particularly interesting: - -<!--(block|syntax("xml"))--> -<plist version="1.0"> -  <dict> -    <key>scores</key> -    <array> -      <dict> -        <key>category</key> -        <string>SMW_Adv_USA1</string> -        <key>context</key> -        <integer>0</integer> -        <key>score-value</key> -        <integer>0</integer> -        <key>timestamp</key> -        <integer>1363515361321</integer> -      </dict> -    </array> -  </dict> -</plist> -<!--(end)--> - -This is a [property list](http://en.wikipedia.org/wiki/Property_list), -containing an identifier for the game, a score (55, in this case), and a -timestamp. Looks pretty simple to mess with. - - -## Modifying and replaying the score submission - -Lets edit the score submission. First, select it in mitmproxy, then press -__enter__ to view it. Make sure you're viewing the request, not the response - -you can use __tab__ to flick between the two. Now press __e__ for edit. You'll -be prompted for the part of the request you want to change - press __r__ for -raw body.  Your preferred editor (taken from the EDITOR environment variable) will -now fire up. Lets bump the score up to something a bit more ambitious: - -<!--(block|syntax("xml"))--> -<plist version="1.0"> -  <dict> -    <key>scores</key> -    <array> -      <dict> -        <key>category</key> -        <string>SMW_Adv_USA1</string> -        <key>context</key> -        <integer>0</integer> -        <key>score-value</key> -        <integer>2200272667</integer> -        <key>timestamp</key> -        <integer>1363515361321</integer> -      </dict> -    </array> -  </dict> -</plist> -<!--(end)--> - -Save the file and exit your editor. - -The final step is to replay this modified request. Simply press __r__ for -replay. - -## The glorious result and some intrigue - -<center> -    <img class="img-responsive" src="@!urlTo('tutorials/leaderboard.png')!@"/> -</center> - -And that's it - according to the records, I am the greatest Super Mega Worm -player of all time. - -There's a curious addendum to this tale. When I first wrote this tutorial, all -the top competitors' scores were the same: 2,147,483,647 (this is no longer the -case, beacause there are now so many fellow cheaters using this tutorial). If -you think that number seems familiar, you're right: it's 2^31-1, the maximum -value you can fit into a signed 32-bit int. Now let me tell you another -peculiar thing about Super Mega Worm - at the end of every game, it submits -your highest previous score to the Game Center, not your current score.  This -means that it stores your highscore somewhere, and I'm guessing that it reads -that stored score back into a signed integer. So, if you _were_ to cheat by the -relatively pedestrian means of modifying the saved score on your jailbroken -phone, then 2^31-1 might well be the maximum score you could get. Then again, -if the game itself stores its score in a signed 32-bit int, you could get the -same score through perfect play, effectively beating the game. So, which is it -in this case? I'll leave that for you to decide. diff --git a/doc-src/tutorials/index.py b/doc-src/tutorials/index.py deleted file mode 100644 index 3bfe7c12..00000000 --- a/doc-src/tutorials/index.py +++ /dev/null @@ -1,7 +0,0 @@ -from countershape import Page - -pages = [ -    Page("30second.html", "Client playback: a 30 second example"), -    Page("gamecenter.html", "Setting highscores on Apple's GameCenter"), -    Page("transparent-dhcp.html", "Transparently proxify virtual machines") -] diff --git a/doc-src/tutorials/leaderboard.png b/doc-src/tutorials/leaderboard.pngBinary files differ deleted file mode 100644 index c1be8df5..00000000 --- a/doc-src/tutorials/leaderboard.png +++ /dev/null diff --git a/doc-src/tutorials/one.png b/doc-src/tutorials/one.pngBinary files differ deleted file mode 100644 index 78a636cf..00000000 --- a/doc-src/tutorials/one.png +++ /dev/null diff --git a/doc-src/tutorials/supermega.png b/doc-src/tutorials/supermega.pngBinary files differ deleted file mode 100644 index d416f71f..00000000 --- a/doc-src/tutorials/supermega.png +++ /dev/null diff --git a/doc-src/tutorials/transparent-dhcp.html b/doc-src/tutorials/transparent-dhcp.html deleted file mode 100644 index 6c648c0d..00000000 --- a/doc-src/tutorials/transparent-dhcp.html +++ /dev/null @@ -1,53 +0,0 @@ -This walkthrough illustrates how to set up transparent proxying with mitmproxy. We use VirtualBox VMs with an Ubuntu proxy machine in this example, but the general principle can be applied to other setups. - -1.  **Configure VirtualBox Network Adapters for the proxy machine** -    The network setup is simple:  `internet <--> proxy vm <--> (virtual) internal network`. -    For the proxy machine, *eth0* represents the outgoing network. *eth1* is connected to the internal network that will be proxified, using a static ip (192.168.3.1). -    <hr>VirtualBox configuration: -    <img class="img-responsive" src="@!urlTo('tutorials/transparent-dhcp/step1_vbox_eth0.png')!@"/><br><br> -    <img class="img-responsive" src="@!urlTo('tutorials/transparent-dhcp/step1_vbox_eth1.png')!@"/> -    <br>Proxy VM: -    <img class="img-responsive" src="@!urlTo('tutorials/transparent-dhcp/step1_proxy.png')!@"/> -    <hr> -2.  **Configure DHCP and DNS** -    We use dnsmasq to provide DHCP and DNS in our internal network. -    Dnsmasq is a lightweight server designed to provide DNS (and optionally DHCP and TFTP) services to a small-scale -    network. - -    -   Before we get to that, we need to fix some Ubuntu quirks: -        **Ubuntu >12.04** runs an internal dnsmasq instance (listening on loopback only) by default -        <a href="https://www.stgraber.org/2012/02/24/dns-in-ubuntu-12-04/">[1]</a>. For our use case, this needs to be -        disabled by changing <br>`dns=dnsmasq` to `#dns=dnsmasq` in */etc/NetworkManager/NetworkManager.conf* -        and running `sudo restart network-manager` afterwards. -    -   Now, dnsmasq can be be installed and configured: -        `sudo apt-get install dnsmasq` -        Replace */etc/dnsmasq.conf* with the following configuration: -        <pre>\# Listen for DNS requests on the internal network -        interface=eth1 -        \# Act as a DHCP server, assign IP addresses to clients -        dhcp-range=192.168.3.10,192.168.3.100,96h -        \# Broadcast gateway and dns server information -        dhcp-option=option:router,192.168.3.1 -        dhcp-option=option:dns-server,192.168.3.1 -        </pre> -        Apply changes: -        `sudo service dnsmasq restart` -        <hr> -        Your proxied machine's network settings should now look similar to this: -        <img class="img-responsive" src="@!urlTo('tutorials/transparent-dhcp/step2_proxied_vm.png')!@"/> -        <hr> - -3.  **Set up traffic redirection to mitmproxy** -    To redirect traffic to mitmproxy, we need to add two iptables rules: -    <pre class="terminal"> -    iptables -t nat -A PREROUTING -i eth1 -p tcp --dport 80 \ -        -j REDIRECT --to-port 8080 -    iptables -t nat -A PREROUTING -i eth1 -p tcp --dport 443 \ -        -j REDIRECT --to-port 8080 -    </pre> - -4.  If required, <a href="@!urlTo('certinstall.html')!@">install the mitmproxy -    certificates on the test device</a>. - -5.  Finally, we can run <code>mitmproxy -T</code>. -    The proxied machine cannot to leak any data outside of HTTP or DNS requests. diff --git a/doc-src/tutorials/transparent-dhcp/step1_proxy.png b/doc-src/tutorials/transparent-dhcp/step1_proxy.pngBinary files differ deleted file mode 100644 index a0c94484..00000000 --- a/doc-src/tutorials/transparent-dhcp/step1_proxy.png +++ /dev/null diff --git a/doc-src/tutorials/transparent-dhcp/step1_vbox_eth0.png b/doc-src/tutorials/transparent-dhcp/step1_vbox_eth0.pngBinary files differ deleted file mode 100644 index 4b7b4e9b..00000000 --- a/doc-src/tutorials/transparent-dhcp/step1_vbox_eth0.png +++ /dev/null diff --git a/doc-src/tutorials/transparent-dhcp/step1_vbox_eth1.png b/doc-src/tutorials/transparent-dhcp/step1_vbox_eth1.pngBinary files differ deleted file mode 100644 index b994d4cb..00000000 --- a/doc-src/tutorials/transparent-dhcp/step1_vbox_eth1.png +++ /dev/null diff --git a/doc-src/tutorials/transparent-dhcp/step2_proxied_vm.png b/doc-src/tutorials/transparent-dhcp/step2_proxied_vm.pngBinary files differ deleted file mode 100644 index 2046cc57..00000000 --- a/doc-src/tutorials/transparent-dhcp/step2_proxied_vm.png +++ /dev/null diff --git a/doc-src/custom-routing.txt b/docs/custom-routing.txt index 2ba2281f..2ba2281f 100644 --- a/doc-src/custom-routing.txt +++ b/docs/custom-routing.txt diff --git a/doc-src/dev/addingviews.html b/docs/dev/addingviews.html index 12623a31..12623a31 100644 --- a/doc-src/dev/addingviews.html +++ b/docs/dev/addingviews.html diff --git a/doc-src/_explicit.graffle/data.plist b/docs/schematics/_explicit.graffle/data.plist index bc5ef104..bc5ef104 100644 --- a/doc-src/_explicit.graffle/data.plist +++ b/docs/schematics/_explicit.graffle/data.plist diff --git a/doc-src/_explicit.graffle/image3.icns b/docs/schematics/_explicit.graffle/image3.icnsBinary files differ index 964df4b8..964df4b8 100644 --- a/doc-src/_explicit.graffle/image3.icns +++ b/docs/schematics/_explicit.graffle/image3.icns diff --git a/doc-src/_explicit.graffle/image6.tiff b/docs/schematics/_explicit.graffle/image6.tiffBinary files differ index bd6ed534..bd6ed534 100644 --- a/doc-src/_explicit.graffle/image6.tiff +++ b/docs/schematics/_explicit.graffle/image6.tiff diff --git a/doc-src/_explicit_https.graffle/data.plist b/docs/schematics/_explicit_https.graffle/data.plist index 306630a0..306630a0 100644 --- a/doc-src/_explicit_https.graffle/data.plist +++ b/docs/schematics/_explicit_https.graffle/data.plist diff --git a/doc-src/_explicit_https.graffle/image3.icns b/docs/schematics/_explicit_https.graffle/image3.icnsBinary files differ index 964df4b8..964df4b8 100644 --- a/doc-src/_explicit_https.graffle/image3.icns +++ b/docs/schematics/_explicit_https.graffle/image3.icns diff --git a/doc-src/_explicit_https.graffle/image6.tiff b/docs/schematics/_explicit_https.graffle/image6.tiffBinary files differ index bd6ed534..bd6ed534 100644 --- a/doc-src/_explicit_https.graffle/image6.tiff +++ b/docs/schematics/_explicit_https.graffle/image6.tiff diff --git a/doc-src/_transparent.graffle/data.plist b/docs/schematics/_transparent.graffle/data.plist index 722b4a44..722b4a44 100644 --- a/doc-src/_transparent.graffle/data.plist +++ b/docs/schematics/_transparent.graffle/data.plist diff --git a/doc-src/_transparent.graffle/image3.icns b/docs/schematics/_transparent.graffle/image3.icnsBinary files differ index 964df4b8..964df4b8 100644 --- a/doc-src/_transparent.graffle/image3.icns +++ b/docs/schematics/_transparent.graffle/image3.icns diff --git a/doc-src/_transparent.graffle/image6.tiff b/docs/schematics/_transparent.graffle/image6.tiffBinary files differ index bd6ed534..bd6ed534 100644 --- a/doc-src/_transparent.graffle/image6.tiff +++ b/docs/schematics/_transparent.graffle/image6.tiff diff --git a/doc-src/_transparent_https.graffle/data.plist b/docs/schematics/_transparent_https.graffle/data.plist index 9c1395d7..9c1395d7 100644 --- a/doc-src/_transparent_https.graffle/data.plist +++ b/docs/schematics/_transparent_https.graffle/data.plist diff --git a/doc-src/_transparent_https.graffle/image3.icns b/docs/schematics/_transparent_https.graffle/image3.icnsBinary files differ index 964df4b8..964df4b8 100644 --- a/doc-src/_transparent_https.graffle/image3.icns +++ b/docs/schematics/_transparent_https.graffle/image3.icns diff --git a/doc-src/_transparent_https.graffle/image6.tiff b/docs/schematics/_transparent_https.graffle/image6.tiffBinary files differ index bd6ed534..bd6ed534 100644 --- a/doc-src/_transparent_https.graffle/image6.tiff +++ b/docs/schematics/_transparent_https.graffle/image6.tiff | 
