

/*******
    Reset CSS
    
    Legend:
        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
        font-family: Georgia, sans-serif;
        font-family: Helvetica, Arial, FreeSans, sans-serif;
        font-family:  Geneva, Tahoma, "Nimbus Sans L", sans-serif;
        font-family: "Lucida Sans Unicode", "Lucida Grande", "Lucida Sans", Lucida, sans-serif;
        font-family: "Trebuchet MS", sans-serif;
        font-family: "Palatino Linotype", "Book Antiqua", Palatino, "Times New Roman", Times, serif;
    
        960px - 1 column
        480px - 2 columns
        320px - 3 columns
        240px - 4 columns
        160px - 6 columns
        120px - 8 columns
*******/
        html, body, div, span, applet, object, iframe,
        h1, h2, h3, h4, h5, h6, p, blockquote, pre,
        a, abbr, acronym, address, big, cite, code,
        del, dfn, em, font, img, ins, kbd, q, s, samp,
        small, strike, strong, sub, sup, tt, var,
        b, u, i, center,
        dl, dt, dd, ol, ul, li,
        fieldset, form, label, legend,
        table, caption, tbody, tfoot, thead, tr, th, td {
            margin: 0;
            padding: 0;
            border: 0;
            outline: 0;
            font-size: 100%;
            vertical-align: baseline;
            background: transparent;
        }
        body {
            line-height: 1;
        }
        ol, ul {
            list-style: none;
        }
        blockquote, q {
            quotes: none;
        }
        blockquote:before, blockquote:after,
        q:before, q:after {
            content: '';
            content: none;
        }
        
        /* remember to define focus styles! */
        :focus {
            outline: 0;
        }
        
        /* remember to highlight inserts somehow! */
        ins {
            text-decoration: none;
        }
        del {
            text-decoration: line-through;
        }
        
        /* tables still need 'cellspacing="0"' in the markup */
        table {
            border-collapse: collapse;
            border-spacing: 0;
        }

/*******
    Base Styles
*******/
        
    body {
        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
        background: #4b6c79;
        height:100%;
        font-size: 12px;
        line-height: 1.5em;
        color: #e3e3e3;
        }

    .body-wrap {
        background: url(../images/background_x.gif) repeat-x;
        }
        
    a {
        color: #57a9c2;
        text-decoration: none;
        }
        
    .container {
        width: 1000px;
        margin: 0 auto;
        background: url(../images/background.jpg) no-repeat;
        padding-top: 97px;
        position: relative;
        }
        
        .container .container-wrap {
            margin: 0 auto;
            }
    
    .wrap {}
    
    .clear {
        clear: both;
        }
    
    .content li {
        margin-left: 20px; /*same as .wrap class */
        list-style-type: disc;
        }
            
    p {
        margin-bottom: 1.5em; 
        }
    
    .header,
    .content,
    .footer {
        width: 902px;
        margin: 0 auto;
        }
    
    h2 {
        font-size: 24px;
        color: #fff;
        font-weight: normal;
        font-family: "Arial Black", Techno, Impact, sans-serif;
        text-shadow: #000 2px 2px;
        margin-bottom: 1em;
        }

    h3 {
        font-size: 16px;
        color: #fff;
        font-weight: normal;
        }
        
        .content h3 a {
            text-decoration: none;
            }
    
    ul {
        margin: 1.5em 0;
        }

        .small {
            font-size: 12px;
            }
        
        p.blockquote {
            padding: 0 20px 0 20px;
            }
    
    .left {
        float: left;
        }
    
    .right {
        float: right;
        }
        .left img {
            margin-right: 10px;
            }
        
        .right img {
            margin-left: 10px;
            }
            
    img.left {
        float: left;
        margin-right: 10px;
        }
    
    img.right {
        float: right;
        margin-left: 10px;
        }
    
    a img {
        text-decoration: none;
        }

/*******
    Z-Indexes
*******/

    #slider {           z-index: 1;        }
    .header a.logo {    z-index: 2;        }
    .nav ul#main-menu { z-index: 3;        }
    .banner {           z-index: 5;        }
    
    /*
        #main-menu li:hover ul,
        #main-menu li.sfHover ul {	z-index: 99;    }
    */
    
/*******
    Top Button Menu
*******/

    .top-button-menu {
        position: absolute;
        top: 0;
        right: 60px;
        width: 92px;
        }
        
        .top-button-menu a span {
            margin-left: -9000px;
            }
        
        .top-button-menu a.home {
            background: url(../images/home_icon.png) no-repeat;
            display: block;
            height: 49px;
            width: 46px;
            float: left;
            }

        .top-button-menu a.email {
            background: url(../images/email_icon.png) no-repeat;
            display: block;
            height: 49px;
            width: 46px;
            float: right;
            }        
/*******
    Header
*******/

    .header {
        position: relative;
        background: url(../images/bg-header.jpg) no-repeat;
        height: 387px;
        width: 902px;
        }
        
        .header a.logo {
            position: absolute;
            background: url(../images/bg-logo.png) 23px 25px no-repeat;
            top: 0;
            left: 0;
            width: 285px;
            height: 85px;
            }
            
            .header a.logo h1 {
                margin-left: -9000px;
                }

/*******
    Slider
*******/

    #slider {
        position: absolute;
        top: 28px;
        left: 15px;
        width: 451px;
        height: 360px;
        overflow: hidden;
        }
        
/*******
    Banner
*******/

    .banner {
        position: absolute;
        top: 411px;
        left: 95px;
        background: url(../images/bg-banner.png) no-repeat;
        height: 55px;
        width: 811px;
        overflow: hidden;
        }
            
        .banner li {
            margin-left: -9000px;
            color: #FFF;
            font-size: 19px;
            font-weight: 900;
            text-decoration: none;
            text-shadow: #000 1px 1px;
            padding-right: 26px;
            display: inline;
            }
/*******
    Content
*******/

    .content-wrap {
        background: #132e3f url(../images/bg-content-top.jpg) top left no-repeat;
        padding: 25px 50px 0 50px;
        }
    
        .content a {
            text-decoration: underline;
            }
            
    .content-footer {
        background: #132e3f url(../images/bg-content-footer.jpg) top left no-repeat;
        height: 16px;
        width: 902px;
        margin: 0 -50px;
        }
/*******
    Footer
*******/

    .footer {
        background: url(../images/bg-footer.png) no-repeat;
        height: 147px;
        font-size: 11px;
        }
        
        .footer a {
            color: #fff;
            }
        
        .footer-wrap {
            padding: 15px 25px;
            text-align: right;
            }
            
            .footer-links {
                float: left;
                }
            
                .footer-links li {
                    display: inline;
                    border-left: 1px solid #fff;
                    padding: 0 5px;
                    }
                    
                    .footer-links li.first {
                        border: none;
                        padding-left: 0;
                        }
/*******
    Home
*******/
    #home .content-wrap {
        padding-right: 0;
        }

    .home-even,
    .home-odd {
        float: left;
        width: 230px;
        padding: 0 20px 0 45px;
        background: url(../images/bg-home-shadow.png) top left no-repeat;
        position: relative;
        height: 230px;
        color: #fff;
        }

        #home-about {
            padding-left: 0;
            background: none;
            }
                    
        #home-contact {
            padding-right: 0;
            }

        .home-even a,
        .home-odd a {
            display: block;
            position: absolute;
            bottom: 5px;
            right: 20px;
            background: url(../images/bg-link-more.jpg) no-repeat;
            width: 59px;
            height: 26px;
            font-size: 11px;
            padding: 4px 0 0 12px;
            color: #fff;
            text-decoration: none;
            }
/*******
    Doug
*******/

    #biography .content li {
        padding-bottom: 1em;
        float: left;
        width: 300px;
        margin-right: 50px;
        }
    
    #biography .content h3 {
        clear: both;
        }
    
    #biography a.inpage-target {
        color: #fff;
        text-decoration: none;
        }
    
    #biography ul.inpage-links li {
        width: 150px;
        }

/*******
    Awards
*******/
    
    #awards .content ul {
        margin-bottom: 1em;
        }
        
    #awards .content h3 {
        margin-bottom: 3px;
        }

/*******
    Contact
*******/

    p.subscribe {
        float: left;
        margin: 3px 10px 0 0;
        }
    
    form.subscribe input.submit {
        margin-left: 6px;
        }
    
    form td {
        padding: 5px;
        }
            
            form td.message {
                vertical-align: top;
                }
    
    form div.errors {
        padding: 25px;
        background: #6BDBFB;
        border: 2px solid #e3e3e3;
        color: #000;
        margin: 1em 0;
        }
    
    form img#vericode {
        float: left;
        margin-right: 10px;
        }

/*******
    Calendar
*******/
    #calendar table.calendar {
        padding: 4px;
        }
        
        table.calendar tr.month-name td {
            padding: 4px 0;
            }
        
            table.calendar tr.month-name a {
                text-decoration: none;
                }
                       
            table.calendar h3 {
                padding: 10px 0 3px 0;
                }

        table.calendar tr.heading {
            background: #57a9c2;
            color: #000;
            margin-bottom: 3px;
            }

            table.calendar th,
            table.calendar td {
                padding: 2px 15px;
                }
                        
            table.calendar th {
                text-align: left;
                }

/*******
    Video Footage
*******/

        table.video-footage tr.heading {
            background: #57a9c2;
            color: #000;
            margin-bottom: 3px;
            }

            table.video-footage th,
            table.video-footage td {
                padding: 2px 15px;
                }

            table.video-footage th {
                text-align: left;
                }

            table.video-footage td img {
                margin-bottom: 5px;
                border: 1px solid #000;
                }
/*******
    Highlight Reels
*******/

        table.highlight-reels tr.heading {
            background: #57a9c2;
            color: #000;
            margin-bottom: 3px;
            }

            table.highlight-reels th,
            table.highlight-reels td {
                padding: 2px 15px;
                }

            table.highlight-reels th {
                text-align: left;
                }
     
/*******
    Galleries
*******/
.highslide-wrapper {
    margin-right: -20px;
    }

    .highslide-item {
    	border: solid 1px #fff;
    	margin: 20px 20px 0 0;
    	width: 180px;
    	float: left;
        }
        
        a.highslide {
            display: table-cell;
            width: 180px;
            height: 180px;
            text-align: center; /* qui e non su precedente, iCab3 */
            vertical-align: middle;
            background: #57a9c2;
            }

        a.highslide img {
            border: solid 1px #000;
            vertical-align: middle;
            }
        
        .highslide-caption a {
            color: #000;
            text-align: center;
            }

/*******
    Same Page Links (biography, lessons, calendar, gallery, contact)
*******/

    ul.inpage-links {
        
        }
        
        .inpage-links li {
            display: inline;
            list-style-type: none;
            }
            
            .inpage-links a {
                display: block;
                width: 150px;
                float: left;
                }

#myspacefacebook .content a.left {
    clear: both;
    height: 349px;
    }
    
    #myspacefacebook .content h3 {
        padding: 15px 0;
        }

/*******
    Flowplayer
*******/

a#player {
    float: right;
    display: block;
    margin-top: 28px;
    width: 400px;
    height: 256px;
    background: url(../images/bg-flowplayer.png) no-repeat;
    text-align: center;
    border:1px outset #ccc;	
    }

#highlight-reels a#player {
    float: right;
    display: block;
    margin-top: 28px;
    width: 400px;
    height: 256px;
    background: url(../images/bg-flowplayer.png) no-repeat;
    text-align: center;
    border:1px outset #ccc;	
    }
/*        
.video-footage {
    float: left;
    width: 350px;
    }
        
        .clips .videos a {
            text-decoration: none;
            }
            
        .clips a img.video-image {
            width: 75px;
            height: 75px;
            float: left;
            margin-right: 10px;
            display: none;
            }
            
            .video-footage a .notes {
                display: block;
                color: #e3e3e3;
                }
*/

/*******
    Default Positioning
    Do not change
*******/

.sf-menu, #main-menu * {
	margin:			0;
	padding:		0;
	list-style:		none;
}
#main-menu {
	line-height:	1.0;
}
#main-menu ul {
	position:		absolute;
	top:			-999em;
	width:			10em; /* left offset of submenus need to match (see below) */
}
#main-menu ul li {
	width:			100%;
}
#main-menu li:hover {
	visibility:		inherit; /* fixes IE7 'sticky bug' */
}
#main-menu li {
	float:			left;
	position:		relative;
}
#main-menu a {
	display:		block;
	position:		relative;
}
#main-menu li:hover ul,
#main-menu li.sfHover ul {
	left:			0;
	z-index:		99;
}
ul#main-menu li:hover li ul,
ul#main-menu li.sfHover li ul {
	top:			-999em;
}
ul#main-menu li li:hover ul,
ul#main-menu li li.sfHover ul {
	left:			10em; /* match ul width */
	top:			0;
}
ul#main-menu li li:hover li ul,
ul#main-menu li li.sfHover li ul {
	top:			-999em;
}
ul#main-menu li li li:hover ul,
ul#main-menu li li li.sfHover ul {
	left:			10em; /* match ul width */
	top:			0;
}

/*******
    First Level Styles
*******/

    .nav {
      	position: relative;
        }

        .nav ul#main-menu {
            position: absolute;
            left: 290px;
            top: 0;
            }
            
            #main-menu {
                float:			left;
                margin-bottom:	1em;
                }
            
                #main-menu li {
                    background:	none;
                    }
            
                    #main-menu li a {
                        padding: 31px 11px;
                        font-size: 13px;
                        color: #fff;
                        background: url(../images/bg-nav-li-a.png) center left no-repeat;
                        }
                        
                        #main-menu li.first a {
                        background: none;
                        }

                        #main-menu li:hover, 
                        #main-menu li.sfHover,
                        #main-menu a:focus, 
                        #main-menu a:hover, 
                        #main-menu a:active {
                            outline: 0;
                            color: #c0c0c0;
                            }

        .sf-sub-indicator { /* IE6 only */
            top: 32px;
            }

        a > .sf-sub-indicator { /* give all except IE6 the correct values */
            top: 32px;
            }

        li li .sf-sub-indicator { /* IE6 only */
            top: 15px;
            }
                                        
/*******
    SubMenu Styles
*******/
    #main-menu li:hover ul,
    #main-menu li.sfHover ul {
        top: 60px;               /* match top ul list item height */
        padding: 0 10px 10px 0; /* for drop-shadow */
        }

        #main-menu li li,
        #main-menu li li:hover, 
        #main-menu li li.sfHover {
            background:	#2b647c url(../images/superfish-dropdown-div.png) bottom repeat-x;
            line-height: 1.5em;
            }

            #main-menu li li:hover, 
            #main-menu li li.sfHover {
                background-color: #57a9c2;
                }
                            
                #main-menu li li a,
                #main-menu li li a:focus, 
                #main-menu li li a:hover, 
                #main-menu li li a:active {
                    background: none;
                    outline: 0;
                    text-decoration: none;
                    color: #fff;
                    padding: 10px 15px; /*padding around elements creates size */
                    }

/*******
    Arrows 
*******/
    #main-menu a.sf-with-ul {
        min-width:		1px;    /* trigger IE7 hasLayout so spans position accurately */
        padding-right: 	1.5em;
        }

        .sf-sub-indicator {
            position:		absolute;
            display:		block;
            right:			.5em;
            width:			10px;
            height:			10px;
            text-indent: 	-999em;
            overflow:		hidden;
            background:		url(../images/superfish-arrows-ffffff.png) no-repeat -10px -100px; /* 8-bit indexed alpha png. IE6 gets solid image only */
            }

        a > .sf-sub-indicator {             /* give all except IE6 the correct values */
            background-position: 0 -100px; /* use translucent arrow for modern browsers*/
            }

            
            a:focus > .sf-sub-indicator,
            a:hover > .sf-sub-indicator,
            a:active > .sf-sub-indicator,
            li:hover > a > .sf-sub-indicator,
            li.sfHover > a > .sf-sub-indicator {    /* apply hovers to modern browsers */
                background-position: -10px -100px; /* arrow hovers for modern browsers*/
                }
    
    #main-menu ul .sf-sub-indicator {   /* point right for anchors in subs */
        background-position:  -10px 0; 
        }
        
        #main-menu ul a > .sf-sub-indicator { 
            background-position:  0 0; 
            }
                
        #main-menu ul a:focus > .sf-sub-indicator,
        #main-menu ul a:hover > .sf-sub-indicator,
        #main-menu ul a:active > .sf-sub-indicator,
        #main-menu ul li:hover > a > .sf-sub-indicator,
        #main-menu ul li.sfHover > a > .sf-sub-indicator {  /* apply hovers to modern browsers */
            background-position: -10px 0;                  /* arrow hovers for modern browsers*/
            }

/*******
    Shadows
*******/

    .sf-shadow ul {
        background:	url(../images/superfish-shadow.png) no-repeat bottom right;
        padding: 0 8px 9px 0;
        -moz-border-radius-bottomleft: 17px;
        -moz-border-radius-topright: 17px;
        -webkit-border-top-right-radius: 17px;
        -webkit-border-bottom-left-radius: 17px;
        }
        
    .sf-shadow ul.sf-shadow-off {
        background: transparent;
        }