/*

<!--

Sections and subsections:

h1/h2/h3/h4, just like in normal HTML

Lists:

ul/ol, just like in normal HTML

Use <ol class="lower-alpha"> for lettered lists

Preformatted code:

pre, just like in normal HTML

Notes:

<div class="note">...</div>
<div class="caution">...</div>
<div class="tip">...</div>

Figures:

<div class="figure" id="..."">
  <img alt="" src="..."/>
  <div>Caption in second div</div>
</div>

Tables:

<table id="...">
  <caption>Table caption</caption>
  <tbody>
    <tr>
      <th>...</th>
      <th>...</th>
      ...    
    </tr>
    <tr>
      <td>...</td>
      <td>...</td>
      ...    
    </tr>
    ...
  </tbody>
</table>

Literature list:

<div class="literature">
   <p id="...">First reference</p>
   <p id="...">Second reference</p>
   ...
</div>

Exercises:

<ol class="exercises">
   <li id="...">First exercise</li>
   <li>Second exercise</li>
   ...  
</ol>

References:

<a href="#..." class="tableref"/>
<a href="#..." class="h2ref"/>
<a href="#..." class="literatureref"/>

To do items:

<p class="todo">...</p>

Character styles:

kbd/.sc: Small caps
var: Variable or variable part of code, in italic
cite/.c: Comment inside code, in roman 
abbr/.gray: Grayed out
samp/.p: Pseudocode
acronym/.black: black-on-white
.url
.u: underline

To inline images: http://www.nczonline.net/blog/2009/11/03/automatic-data-uri-embedding-in-css-files/

-->

TODO: Big Java Styles

*/

body > p, body > ul, body > div { 
  margin-left: 1em;
}

div.margin {
    margin-left: 0em;
    font-family: sans-serif;
    font-size: 0.8em; 
    float: left;
    width: 10em;
    background-color: cornsilk;
    padding: 0.5em;
    margin-right: 1em;
    margin-bottom: 0.5em;
}

div.rightimg {
    float: right;
    width: 10em;
    font-family: sans-serif;
    font-style: italic;
    margin-left: 2em;
}

div.leftimg {
    float: left;
    width: 10em;
    font-family: sans-serif;
    font-style: italic;
    margin-right: 2em;
}

div.rightimg > img, div.leftimg > img {
    width: 90%;
}

@font-face {
  font-family: "MonoCondensed";
  src: local("DejaVu Sans Mono Condensed"), url("http://horstmann.com/MySlidy/DejaVuSansMonoCondensed.otf") format("opentype");
}

@font-face {
  font-family: "Handwriting";
  src: local("MarkingPen"), url("http://horstmann.com/MySlidy/Satisfy.ttf") format("truetype");
}

@media print { 
  h1 {
    page-break-before: always;
  }

  @font-face {
    font-family: "serif";
    src: local("FreeSerif")
  }

  @font-face {
    font-family: "sans-serif";
    src: local("DejaVu Sans")
  }

  .indexterm {
      display: none;
  }
}

h1, h2, h3, h4 {
    font-family: sans-serif;
}

pre, code, .code, .url { 
  font-family: "MonoCondensed", monospace
}

ul { 
  list-style-type: square;
}


.u, .url {
  text-decoration: underline; 
}

del, .ul {
  text-decoration: line-through;
}

body { 
  font-family:  serif
}

kbd, .sc { 
  font-family:  serif;
  font-variant: small-caps;
  text-transform: lowercase; 
  font-style: normal;
}

var {
  font-style: italic;
  font-family:  serif
}

var code, var .code { 
  font-style: normal;
}

samp, .hand, .pseudo, .p {
  font-style: normal;
  font-family: "Handwriting", "Comic Sans MS", serif
}

samp b, .hand b, .pseudo b, .p b, pre b, code b, samp strong, .hand strong, .pseudo strong, .p strong, pre strong, code strong {
  font-weight: normal;
  color: blue;
}

pre cite, code cite, pre .c, code .c, pre .rm, code .rm, pre .comment, code .comment {
  font-style: normal;
  font-family:  serif
}

abbr, .gray { 
  color: gray;
}

acronym, .black { 
  color: white;
  background: black;
}

pre { 
  margin-left: 1em;  
}

body > pre { 
  margin-left: 2em;  
}

.Note, .note, .Tip, .tip, .Caution, .caution, .q, .a { 
  background-repeat: no-repeat; 
  padding-left: 70px;
  min-height: 50px;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
  padding-top: 0.2em;
  padding-bottom: 0.2em;
}

div.def {
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  padding-left: 1.2em;
  padding-right: 1.2em;
  background-color: cornsilk;
}

div.theorem {
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  padding-left: 1.2em;
  padding-right: 1.2em;
  background-color: lightsteelblue;
}

div.participation {
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  padding-left: 1.2em;
  padding-right: 1.2em;
  background-color: #eee;
}

div.ex {
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  padding-left: 1.2em;
  padding-right: 1.2em;
  background-color: #eeeeff;
}

div.ex:before {
    content: "Exercise: ";
    font-weight: bold;
}

div.participation > p:first-child:before {
    content: "Participation Exercise: ";
    font-weight: bold;
}

.q {
    background-color: #ffc5c5;
}

.a {
    background-color: #c5ffd9;
}

div.def > p:first-child:before {
  content: "Definition: ";
  font-weight: bold;
}

div.theorem > p:first-child:before {
  content: "Theorem: ";
  font-weight: bold;
}


div.Note > p:first-child:before, p.Note:before, div.note > p:first-child:before, p.note:before {
  content: "Note: ";
  font-weight: bold;
}

div.Tip > p:first-child:before, p.Tip:before, div.tip > p:first-child:before, p.tip:before {
  content: "Tip: ";
  font-weight: bold;
}

div.Caution > p:first-child:before, p.Caution:before, div.caution > p:first-child:before, p.caution:before { 
  content: "Caution: ";
  font-weight: bold;
}

table {
  border-collapse: collapse;
  border-style: solid;
  border-width: thin;
  margin-left: 2em;
  margin-right: 2em;  
  margin-bottom: 1em;
}

table caption { 
  margin-top: 1em;
  margin-left: 2em;
  margin-right: 2em;  
  margin-bottom: 0.5em;
}

table td {
  border-style: solid;
  border-width: thin;
  padding: 3pt;
}

table th {
  border-style: solid;
  border-width: thin;
  padding: 3pt;
}

.TBD:before, .todo:before { 
  color: red;
  content: "TODO: " ;
}

.TBD, .todo { 
  color: red;
}

table caption:before { 
  content: "Table " counter(h1) "-" counter(table) ": ";
}

table[id] { 
  counter-increment: table;
}

table caption { 
    text-align: left;
}

body { 
  counter-reset: table;
  counter-reset: figure;
  counter-reset: literature;
  counter-reset: exr;
  counter-reset: exe;
  counter-reset: exp;
  counter-reset: selfcheck;
  counter-reset: special;
  counter-reset: tip;
  counter-reset: error;
  counter-reset: howto;
  counter-reset: workedex;
  counter-reset: java8;
}

@media print { 
  a.tableref { 
    content: "Table " counter(h1) "-" target-counter(attr(href), table) ;
    text-decoration: none;
    color: black;
  }

  a.figureref { 
    content: "Figure " target-counter(attr(href), figure) ;
    text-decoration: none;
    color: black;
  }

  a.literatureref { 
    content: "[" target-counter(attr(href), literature) "]" ;
    text-decoration: none;
    color: black;
  }

 a.specialref { 
    content: "Special Topic" target-counter(attr(href), h1) "." target-counter(attr(href), special) ;
    text-decoration: none;
    color: black;
  }
  a.tipref { 
    content: "Programming Tip" target-counter(attr(href), h1) "." target-counter(attr(href), tip) ;
    text-decoration: none;
    color: black;
  }

  a.errorref { 
    content: "Common Error" target-counter(attr(href), h1) "." target-counter(attr(href), error) ;
    text-decoration: none;
    color: black;
  }  

  a.h2ref { 
    content: "Section " target-counter(attr(href), h2);
    text-decoration: none;
    color: black;
  }

  a.h3ref { 
    content: "Section " target-counter(attr(href), h2) "." target-counter(attr(href), h3);
    text-decoration: none;
    color: black;
  }

  a.exerciseref, a.exref { 
    content: "Exercise " target-counter(attr(href), exercise) ;
    text-decoration: none;
    color: black;
  }

a.exrref { 
    content: "R" target-counter(attr(href), h1) "." target-counter(attr(href), exr) ;
    text-decoration: none;
    color: black;
  }

  a.exeref { 
    content: "E" target-counter(attr(href), h1) "." target-counter(attr(href), exe) ;
    text-decoration: none;
    color: black;
  }
  
  a.expref { 
    content: "P" target-counter(attr(href), h1) "." target-counter(attr(href), exp) ;
    text-decoration: none;
    color: black;
  }

  a.java8ref { 
    content: "Java 8 Note " target-counter(attr(href), h1) "." target-counter(attr(href), java8) ;
    text-decoration: none;
    color: black;
  }  
}



.chapterRef:before, chapterref:before { 
  content: "the “";
  font-variant: normal;
}

.chapterRef:after, chapterref:after { 
  content: "” chapter";
  font-variant: normal;
}

@media screen { 
  a.tableref:after { 
    font-variant: small-caps;
    content: "this table"
  }

  a.figureref:after { 
    font-variant: small-caps;
    content: "this figure"
  }

  a.literatureref:after { 
    font-variant: small-caps;
    content: "this reference"
  }

  a.exerciseref:after, a.exref:after { 
    font-variant: small-caps;
    content: "this exercise"
  }

a.specialref:after { 
    font-variant: small-caps;
    content: "this special topic"
  }

  a.tipref:after { 
    font-variant: small-caps;
    content: "this programming tip"
  }

  a.errorref:after { 
    font-variant: small-caps;
    content: "this common error"
  }

  a.exeref:after, a.exrref:after, a.expref:after { 
    font-variant: small-caps;
    content: "this exercise"
  }

  a.java8ref:after { 
    font-variant: small-caps;
    content: "this java 8 note"
  }

  a.h2ref:after { 
    font-variant: small-caps;
    content: "this section"
  }

  a.h3ref:after { 
    font-variant: small-caps;
    content: "this section"
  }
}

body { 
  counter-reset: h1;
}

h1, h2, h3, h4, h5, h6 { 
  font-family: sans-serif;
}

h1:before {
  content: counter(h1) ". ";
}

h1 {
  counter-reset: h2 figure table;
  counter-increment: h1;
}

h2:before {
  content: counter(h1) "." counter(h2) ". ";
}

h2 {
  counter-increment: h2;
}

h2 { 
  counter-reset: h3;
}

h2.exercises:before { 
  content: "";
}



h3:before { 
  content: counter(h1) "." counter(h2) "." counter(h3) ". ";
}

h3 { 
  counter-increment: h3;
}

div.literature { 
}

div.literature p:before {
  content: "[" counter(literature) "] ";
}

div.literature p {
  counter-increment: literature;
}

ol.exercises li {
  counter-increment: exercise;
}

div.exr > ol, div.exe > ol, div.exp > ol {
    list-style: none;
}

div.exr > ol > li, div.exe > ol > li, div.exp > ol > li {
    margin-bottom: 0.5em;
}

div.exr > ol > li {
    counter-increment: exr;
}

div.exe > ol > li {
  counter-increment: exe;
}

div.exp > ol > li {
  counter-increment: exp;
}

div.exr > ol > li.hard:before {
    content: "***R" counter(exr) ". ";
    font-weight: bold;
}

div.exr > ol > li.easy:before {
    content: "*R" counter(exr) ". ";
    font-weight: bold;
}

div.exr > ol > li:before {
    content: "**R" counter(exr) ". ";
    font-weight: bold;
}

div.exe > ol > li.hard:before {
    content: "***E" counter(exe) ". ";
    font-weight: bold;
}

div.exe > ol > li.easy:before {
    content: "*E" counter(exe) ". ";
    font-weight: bold;
}

div.exe > ol > li:before {
    content: "**E" counter(exe) ". ";
    font-weight: bold;
}

div.exp > ol > li.hard:before {
    content: "***P" counter(exp) ". ";
    font-weight: bold;
}

div.exp > ol > li.easy:before {
    content: "*P" counter(exp) ". ";
    font-weight: bold;
}

div.exp > ol > li:before {
    content: "**P" counter(exp) ". ";
    font-weight: bold;
}


div.figure { 
  counter-increment: figure;
  padding: 2em;
}

div.figure div:before { /* the caption */
  content: "Figure " counter(h1) "-" counter(figure) ": ";
}

.lower-alpha > li, .la > li { 
  list-style-type: lower-alpha;
}

.hide-link { 
    text-decoration: none;
    color: black;
}

@page {
    @bottom {
        content: counter(page)
    }
}

div.chapter-goals:before {
    content: "Chapter Goals";
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: green;
    padding: .5em;
    border-radius: .25em;
}

div.a:before {
    content: "Click to show answer";
}

div.a > * {
    visibility: hidden;
}

div.a.revealed > * {
    visibility: visible;
}

div.a.revealed:before {
    content: "";
}



.q {
    background-image: url(q.png);
    margin-left: 2em;
}

.a {
    background-image: url(a.png);
    margin-left: 2.5em;
}

.Note, .note {
  background-image: url();
  background-color: #ffffcc;
}

.Tip, .tip { 
  background-image: url();
  background-color: #b4e2d8;
}

.Caution, .caution {
  background-image: url();
  background-color: #fed0d3;
}

div.chapter-goals:before {
    content: "Chapter Goals";
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: green;
    padding: .5em;
    border-radius: .25em;
}

div.worked-example:before {
    content: "Worked Example " counter(h1) "." counter(workedex);
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: #006CB7;
    padding: .5em;
    border-radius: .25em;
}

div.worked-example {
    margin-top: 1em;
    counter-increment: workedex;
    counter-reset: step;    
    border-left: thick solid #006CB7;
    padding-left: 1em;
}

div.howto:before {
    content: "How To " counter(h1) "." counter(howto);
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: #006CB7;
    padding: .5em;
    border-radius: .25em;
}

div.howto {
    margin-top: 1em;
    counter-increment: howto;
    counter-reset: step;
    border-left: thick solid #006CB7;
    padding-left: 1em;
}

.step {
    counter-increment: step;
    font-weight: bold;
}

.step:before {
    content: "Step " counter(step) " ";
    color: #006CB7;
}

div.special-topic:before {
    content: "Special Topic " counter(h1) "." counter(special);
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: #1FADAE;
    padding: .5em;
    border-radius: .25em;
}

div.special-topic {
    margin-top: 1em;
    counter-increment: special;
    padding-left: 1em;
    border-left: thick solid #1FADAE;
}

div.programming-tip:before {
    content: "Programming Tip " counter(h1) "." counter(tip);
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: #828EBC;
    padding: .5em;
    border-radius: .25em;
}

div.programming-tip {
    margin-top: 1em;
    counter-increment: tip;
    padding-left: 1em;
    border-left: thick solid #828EBC;
}

div.common-error:before {
    content: "Common Error " counter(h1) "." counter(error);
    color: white;
    font-size: 1.2em;
    font-family: sans-serif;
    font-weight: bold;
    background: #89B950;
    padding: .5em;
    border-radius: .25em;
}

div.common-error {
    margin-top: 1em;
    counter-increment: error;
    padding-left: 1em;
    border-left: thick solid #89B950;
}

div.self-check {
   margin: .5em;
   counter-increment: selfcheck;
}


div.self-check:before {
    content: "Self Check " counter(selfcheck) " ";
    border-radius: .25em;
    color: white;
    font-family: sans-serif;
    font-size: 0.8em;
    font-weight: bold;
    background: #C92354;
    padding: .125em;
    margin-right: .5em;
}

div.answer:before {
    content: "Answer: ";
    font-weight: bold;
    font-family: sans-serif;
    font-size: 0.9em;
}


div.answer {
    margin-left: 0.5em;
    margin-top: 0.5em;
    font-size: 0.9em;
}



div.intro {
    background: #FFE06A;
    padding: 0.5em;

}

div.intro img {
    float: left;
    margin-right: 1em;
}

.margin {
  font-family: sans-serif;
  font-size: 0.8em; 
  float: left;
  width: 10em;
  background-color: cornsilk;
  padding: 0.5em;
  margin-right: 1em;
  margin-bottom: 0.5em;
}

.title {
  font-family: sans-serif;
  font-size: 1.2em;
  font-weight: bold;
}

.listing {
  font-family: sans-serif;
  font-weight: bold;
  color: blue;
}

div.code-example {
    margin-left: 0em;
    font-family: sans-serif;
    font-size: 0.8em; 
    float: left;
    width: 15em;
    background-color: #EAEFF9;
    padding: 0.5em;
    margin-right: 1em;
    margin-bottom: 0.5em;
}

div.code-example:before {
    content: "FULL CODE EXAMPLE";
    background-color: #006CB7;
    color: white;
    font-family: sans-serif;
    font-weight: bold;    
}

div.code-example > p:first-child:before  {
    content: "Go to wiley.com/go/bigjava to download a program ";
}

.output:before {
  font-family: sans-serif;
  font-weight: bold;
  color: blue;
  content: "Program Run"
}

div.exr:before {
    content: "Review Exercises";
    color: #006CB7;
    font-family: sans-serif;
    background: #FFE06A;
    padding: .25em;
    border-radius: .125em;
}

div.exe:before {
    content: "Practice Exercises";
    color: #006CB7;
    font-family: sans-serif;
    background: #FFE06A;
    padding: .25em;
    border-radius: .125em;
}

div.exp:before {
    content: "Programming Projects";
    color: #006CB7;
    font-family: sans-serif;
    background: #FFE06A;
    padding: .25em;
    border-radius: .125em;
}

div.practice:before {
    content: "Practice It ";
    font-family: sans-serif;
    color: #C92354;
    margin-left: -1em;
}

div.practice > span:first-child:before {
    content: "Now you can try these exercises at the end of the chapter: "
}

div.standard:before {
    content: "Standard Library Items Introduced in this Chapter";
    color: yellow;
    font-family: sans-serif;
    background: black;
    padding: .25em;
    border-radius: .25em;
}


div.java8 {
  counter-increment: java8;
  background-repeat: no-repeat; 
  background-image: url(eightball.jpeg);    
  padding-left: 85px;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  border-left: thick solid black;

}

.java8 > p:first-child:before {
  content: "Java 8 Note: " counter(h1) "." counter(java8) ". ";
  font-weight: bold;
}        

.images * { 
    vertical-align: top;
}

.images img {
    width: 60%;
}

.back:before {
    content: "◀";
    font-size: 3em;
    color: orange;
    padding: 0.2em;
}

.forward:before {
    content: "▶";
    font-size: 3em;             
    color: orange;
    padding: 0.2em;
}

dk\:level {
    color: white;
    background: black;
}

d\:indexterm {
    display: none;
}

