@charset "UTF-8";

/*==================================================================================================

       Normal ヘッダー

===================================================================================================*/

header.normal-header {
	position:relative;
    width:100%;
    height: 156px;
    box-sizing: border-box;
	z-index:9;
	}
	.normal-header-wrap {
        width: 100%;
        height: 156px;
        background: url("../images/parts/beige.jpg") right top repeat;
        position:relative;
        z-index:999;
        -webkit-transition:all .3s ease;
        -moz-transition  : all .3s ease;
        -o-transition    : all .3s ease;
        -ms-transition   : all .3s ease;
        transition       : all .3s ease;
        }
        .normal-header-wrap:before {
        content:"";
        display: block;
        position: absolute;
        bottom:-4px;
        left:0;
        width:100%;
        height:3px;
        background: url("../images/parts/line.png") center center repeat-x;
        }
        .normal-header-wrap:after {
        content:"";
        display: block;
        position: absolute;
        top:50%;
        left:50%;
        -webkit-transform: translate(-50%,-50%);
        transform: translate(-50%,-50%);
        width:2009px;
        height:159px;
        background: url("../images/parts/header-cover.png") center center repeat-x;
        }
        .normal-navigation-wrap {
                width:100%;
                max-width:1240px;
                margin:0 auto;
                box-sizing:border-box;
                position:relative;
                z-index: 10;
                }
                .normal-logo {
                width:234px;
                position: absolute;
                top:-25px;
                left:20px;
                line-height:1;
                text-align: center;
                box-sizing: border-box;
                z-index:1;
                -webkit-transition:all .3s ease;
                -moz-transition  : all .3s ease;
                -o-transition    : all .3s ease;
                -ms-transition   : all .3s ease;
                transition       : all .3s ease;
                }
                .normal-logo:after {
                content:"";
                display: block;
                position: absolute;
                bottom:15px;
                left:-255px;
                width:956px;
                height:514px;
                background: url("../images/parts/rame.png") center center / cover;
                z-index: -1;
                }

        /*=================================================
                main navigation
        ==================================================*/

        .normal-navigation {
                position:absolute;
                top:0;
                left:520px;
                width:568px;
                z-index: 20;
                }
                .normal-main-nav {

                }
                .normal-main-nav li {
                background: url("../images/parts/menu-line.png") left center no-repeat;
                z-index: 1;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .normal-main-nav li:last-child {

                }
                .normal-main-nav li a {
                font-size: 18px;
                padding: 32px 24px;
                height: 100%;
                line-height: 135%;
                font-weight:600;
                letter-spacing: .3rem;
                color:#303030;
                box-sizing: border-box;
                display: block;
                -webkit-transition:all .3s ease;
                -moz-transition  : all .3s ease;
                -o-transition    : all .3s ease;
                -ms-transition   : all .3s ease;
                transition       : all .3s ease;
                }
                .normal-main-nav li a:hover { background:rgba(255,255,255,.5); }
                .normal-main-nav li:last-child a {
                background: url("../images/parts/red.jpg") left top repeat;
                color:#FFF;
                }
                .normal-main-nav li:last-child a:hover { opacity: .6; color:#FFF; }

                /*=================================================
                        hover bar
                ==================================================*/

                .normal-main-nav li a {
                position: relative;
                display: inline-block;
                transition: .3s;
                }
                .normal-main-nav li a:after {
                position:absolute;
                bottom:0;
                left:0;
                content:'';
                width:0;
                height:2px;
                background-color:#8A7158;
                transition:.3s;

                }
                .normal-main-nav li a:hover:after {
                width:100%;
                }
                .normal-main-nav li a:hover {
                opacity:1;
                color:#8A7158;
                }





.foreign-navigation {
    position:absolute;
    right:10px;
    width:100%;
    z-index: 20;
	margin: 8px 10px 0 0;
                }

.foreign-navigation ul {
display: flex;
justify-content: flex-end;
                }
.foreign-navigation_sp ul {
display: flex;
justify-content: flex-start;
	flex-wrap: wrap;
                }


.foreign-navigation li {
	margin: 3px 0px 0 10px;
	 width: 100px;
                }

.foreign-navigation_sp li {
    margin: 3px 0px 0 0px;
    padding: 0 10px 10px 0px;
    /* width: 90px;*/
                }

.foreign-navigation a {
background: url(../images/parts/black.jpg) center center repeat;
    color: #FFF;
	font-size: 12px;
	margin: 2px 0;
	width:100px;
	display: block;
    box-sizing: border-box;
    text-align: center !important;
                }
.foreign-navigation_sp a {
background: url(../images/parts/black.jpg) center center repeat;
    color: #FFF;
	font-size: 12px;
	margin: 2px 0;
	width:100px;
	display: block;
    box-sizing: border-box;
    text-align: center !important;
                }

.foreign-navigation_sp a {
background: url(../images/parts/black.jpg) center center repeat;
    color: #FFF;
	font-size: 14px;
	margin: 2px 0;
	display: block;
    box-sizing: border-box;
    text-align: center !important;
                }


@media screen and (max-width: 1024px){
    .foreign-navigation {
		display: none;
                }
        }


        /*=================================================
                Responsive
        ==================================================*/

        @media screen and (max-width: 1120px) {
        .normal-navigation { left:auto; right:20px; }
        }

/*==================================================================================================

       Fixed ヘッダー

===================================================================================================*/

header.main-header { position: relative; z-index: 10000;}
        .header-wrap {
        position: fixed;
        background: url("../images/parts/beige.jpg") right top repeat;
        width:100%;
        height:110px;
        margin-top:-120px;
        opacity:0;
        box-sizing: border-box;
        z-index:1000;
        -webkit-transition: all .3s ease;
        -moz-transition: all .3s ease;
        -ms-transition: all .3s ease;
        -o-transition: all .3s ease;
        transition: all .3s ease;
        }
        .header-wrap:after {
        content:"";
        display: block;
        position: absolute;
        bottom:0;
        left:50%;
        -webkit-transform: translate(-50%);
        transform: translate(-50%);
        width:2009px;
        height:159px;
        background: url("../images/parts/header-cover.png") center center repeat-x;
        }
        .header-wrap.fixed { top:0; opacity: 1; margin-top:0; }
        .header-wrap.pages { top:0; opacity: 1; margin-top:0; }
        .fixed-navigation-wrap {
                display: block;
                position: relative;
                width:100%;
                max-width:1440px;
                margin:0 auto;
                box-sizing: border-box;
                z-index: 2;
                }
                .fixed-logo {
                width:190px;
                position: absolute;
                top:-44px;
                left:20px;
                opacity: 1;
                line-height: 100%;
                z-index: 10;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-logo:after {
                content:"";
                display: block;
                position: absolute;
                bottom:15px;
                left:-255px;
                width:956px;
                height:514px;
                background: url("../images/parts/rame.png") center center / cover;
                z-index: -1;
                }

        /*=================================================
                main navigation
        ==================================================*/

        .fixed-navigation {
                position:absolute;
                top:22px;
                right:230px;
                width:850px;
                z-index: 20;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-main-nav {
                float: right;
                position:relative;
                text-align: center;
                }
                .fixed-main-nav li {
                display: inline-block;
                position: relative;
                font-weight: 500;
                letter-spacing: .05em;
                text-align: center;
                box-sizing: border-box;
                padding-right:3rem;
                z-index: 1;
                }
                .fixed-main-nav li:last-child {
                padding-right:0;
                }
                .fixed-main-nav li a {
                font-size:16px;
                padding:5px 0;
                line-height: 110%;
                letter-spacing: .05rem;
                color:#303030;
                display: block;
                -webkit-transition:all .3s ease;
                -moz-transition  : all .3s ease;
                -o-transition    : all .3s ease;
                -ms-transition   : all .3s ease;
                transition       : all .3s ease;
                }
                .fixed-main-nav li a span {
                font-size:12px;
                opacity:.5;
                letter-spacing: 0;
                }

                /*=================================================
                        hover bar
                ==================================================*/

                .fixed-main-nav li a {
                position: relative;
                display: inline-block;
                transition: .3s;
                }
                .fixed-main-nav li a:after {
                position:absolute;
                bottom:0;
                left:50%;
                content:'';
                width:0;
                height:2px;
                background-color:#8A7158;
                transition:.3s;
                -webkit-transform: translateX(-50%);
                transform: translateX(-50%); 
                }
                .fixed-main-nav li a:hover:after {
                width:100%;
                }
                .fixed-main-nav li a:hover {
                opacity:1;
                color:#8A7158;
                }
                
        /*=================================================
                Reservation btn
        ==================================================*/

        .fixed-reservation {
                position: absolute;
                text-align: center;
                top:10px;
                right:20px;
                width:170px;
                height: 60px;
                letter-spacing: 0;
                font-size:17px;
                z-index: 99999;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-reservation a {
                width:100%;
                height:60px;
                box-sizing: border-box;
                text-align: center;
                line-height: 60px;
                font-weight:500;
                letter-spacing: 0;
                display:block;
                color:#FFF;
                background: url("../images/parts/red.jpg") center top repeat;
                overflow: hidden;
                white-space: nowrap;
                text-decoration:none !important;
                position: relative;
                z-index: 1;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .fixed-reservation a:after {
                position: absolute;
                content: "";
                width: 0;
                height: 100%;
                top: 0;
                right: 0;
                z-index: -1;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                background: rgba(255,255,255,.35);
                }
                .fixed-reservation a:hover:after {
                left: 0;
                width: 100%;
                }
                .fixed-reservation a:hover {
                opacity:1;
                filter: alpha(opacity=100);
                -ms-filter: "alpha( opacity=100 )";
                color:#FFF;
                }

        /*=================================================
                fixed
        ==================================================*/
                
        .header-wrap.fixed {
                height:80px;
                top:0;
                -webkit-box-shadow: 0px 3px 8px rgba(0,0,0,.1);
                -moz-box-shadow:	0px 3px 8px rgba(0,0,0,.1);
                -ms-box-shadow:		0px 3px 8px rgba(0,0,0,.1);
                -o-box-shadow:		0px 3px 8px rgba(0,0,0,.1);
                box-shadow:	        0px 3px 8px rgba(0,0,0,.1);
                }
        .header-wrap.fixed .fixed-logo {  }
        .header-wrap.fixed .fixed-navigation {  }
        .header-wrap.fixed .fixed-sub-nav {  }
        .header-wrap.fixed .fixed-reservation {  }
        .header-wrap.fixed .fixed-reservation a {  }

        /*=================================================
                Responsive
        ==================================================*/

        @media screen and (max-width: 1150px) {
        .fixed-navigation { right:200px; }
        .fixed-main-nav li { padding-right:2rem; }
        .fixed-reservation { width:140px; }
        }

/*==================================================================================================

       Mobile ヘッダー

===================================================================================================*/

.header-wrap-sp {
        display: none;
        position: absolute;
        width:100%;
        height:90px;
        z-index: 1;
        background: url("../images/parts/beige.jpg") right top repeat;
        }
        .mobile-logo {
                width:170px;
                position: absolute;
                top:-30px;
                left:3%;
                opacity: 1;
                z-index: 999;
                line-height: 100%;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-logo:after {
                content: "";
                display: block;
                position: absolute;
                bottom: 25px;
                left: -19vw;
                width: 100vw;
                height: 0;
                padding-bottom: 206%;
                background: url("../images/parts/rame.png") center center / cover;
                z-index: -1;
                }

        /*=================================================
                ハンバーガー
        ==================================================*/

        .gnav {
                font-family: 'Poppins', sans-serif;
                letter-spacing: 0;
                }
                .nav-toggle {
                display:block;
                position:fixed;
                right:10px;
                top:11px;
                padding:0;
                width:70px;
                height:70px;
                text-align: center;
                font-size: 0px;
                letter-spacing: 0;
                box-sizing: border-box;
                pointer-events: auto;
                cursor:pointer;
                z-index:99999;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .nav-toggle div {
                position:absolute;
                width:27px;
                height:10px;
                top:25px;
                right:21px;
                }
                .nav-toggle span {
                display: block;
                position: absolute;
                height: 2px;
                width:27px;
                background:#393735;
                border-radius:2px;
                left: 0;
                -webkit-transition: .3s ease-in-out;
                -moz-transition: .3s ease-in-out;
                transition: .3s ease-in-out;
                }
                .nav-toggle span:nth-child(1) { top: 0; }
                .nav-toggle span:nth-child(2) { top: 8px; }
                .gnav.active .nav-toggle span { background: #393735; }
                .gnav.active .nav-toggle span:nth-child(1) {top: 3px;-webkit-transform: rotate(315deg);-moz-transform: rotate(315deg);transform: rotate(315deg);}
                .gnav.active .nav-toggle span:nth-child(2) {top: 3px;-webkit-transform: rotate(-315deg);-moz-transform: rotate(-315deg);transform: rotate(-315deg);}
                
                
                .gnav .menu  { opacity: 1; position: absolute; width:27px; right:21px; top:42px; line-height: 1; font-size:10px; color:#393735; -webkit-transition : all 0.3s ease-in-out;  -moz-transition : all 0.3s ease-in-out; -o-transition : all 0.3s ease-in-out;}
                .gnav .close { opacity: 0; position: absolute; width:31px; right:19px; top:42px; line-height: 1; font-size:10px; color:#393735;  -webkit-transition : all 0.3s ease-in-out; -moz-transition : all 0.3s ease-in-out; -o-transition : all 0.3s ease-in-out;}
                .gnav.active .menu  { opacity: 0; }
                .gnav.active .close { opacity: 1; }
                
                
                .header-wrap-sp.fixed .nav-toggle span { background: #393735; }
                .header-wrap-sp.fixed .active .nav-toggle span { background: #393735; }
                .header-wrap-sp.fixed .gnav .menu  { color: #393735; }

        /*=================================================
                オリジナルセット
        ==================================================*/



        /*=================================================
                ナビゲーション
        ==================================================*/

        .gnav-content {
                display: none;
                position: fixed;
                right: 0;
                top: 0;
                width: 100%;
                height: 100%;
                background: url("../images/parts/beige.jpg")  left top repeat;
                overflow: auto;
                z-index:9999;
                }
                .gnav-logo {
                width:170px;
                position: absolute;
                top:-30px;
                left:3%;
                opacity: 1;
                z-index: 999;
                line-height: 100%;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-navigation {
                margin-top:170px;
                width:100%;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-main-nav {
                position:relative;
                padding-bottom:1rem;
                }
                .mobile-main-nav li {
                width:100%;
                text-align: left;
                font-weight:400;
                border-bottom:1px solid #8A7158;
                }
                .mobile-main-nav li:last-child {
                border-bottom:none;
                }
                .mobile-main-nav li a {
                letter-spacing: 0.01em;
                padding:15px 0;
                display:block;
                font-size:1.375rem;
                position: relative;
                color:#232323;
                box-sizing: border-box;
                background:none;
                }
                .mobile-main-nav li a span { color:#B59B66; font-size:10px; margin-left:1rem;}
                .mobile-main-nav li:not(.acordion) a:after {
                position: absolute;
                content: '';
                width: 6px;
                height: 6px;
                border: 0;
                border-top: solid 1px #8A7158;
                border-right: solid 1px #8A7158;
                top: 45%;
                right: 12px;
                transform: rotate( 45deg );
                }
                .mobile-main-nav li li {
                border-top:1px solid rgba(255,255,255,.4);
                border-bottom:none;
                }
                .mobile-main-nav li li a {
                font-size:0.85rem;
                padding-left:1.5rem;
                }
                /*
                .mobile-reservation { position:relative;  }
                .mobile-main-nav li.mobile-reservation { border-bottom:none; }
                .mobile-main-nav li.mobile-reservation a { letter-spacing: 0.01em; padding:15px 0 ; text-align:center; display:block; font-size:1rem; position: relative; background: #FFF; color:#FFF; font-weight:500; }
                .mobile-main-nav li.mobile-reservation a:after { display:none; }
                */
        /*=================================================
                SNS btn
        ==================================================*/

        .mobile-sns-nav {
                position: relative;
                padding:.75rem 0;
                text-align: center;
                }
                .mobile-sns-nav li {
                width:32px;
                height:32px;
                display: inline-block;
                margin:0 6px;
                }
        .mobile-menu { display: none; }

        @media screen and (max-width: 1024px) {
        header.main-header { position: absolute; width:100%; }
        .header-wrap { display:none; }
        .header-wrap-sp { margin-top:0; display:block; opacity: 1; }
        }


        @media screen and (max-width: 767px) {
        .header-wrap-sp { height:80px; position: relative; }
        .mobile-logo { width:150px; top:-26px; }
        .gnav-logo { width:150px; top:-26px; }
        .nav-toggle { top:5px; }
        .mobile-navigation { margin-top: 120px; }
        
        .header-wrap-sp.fixed .nav-toggle span { background: #1D1B19; }
        .header-wrap-sp.fixed .gnav .menu  { color: #1D1B19; }
        
        .tablet-phone { display: none; }
        .tablet-reservation { display: none; }
        
        .mobile-menu {
                display: block;
                position: fixed;
                bottom:0;
                left:0;
                width:100%;
                height: 60px;
                z-index: 10000;
                -webkit-box-shadow: 0px 0px 10px rgba(0,0,0,.2);
                -moz-box-shadow:	0px 0px 10px rgba(0,0,0,.2);
                -ms-box-shadow:		0px 0px 10px rgba(0,0,0,.2);
                -o-box-shadow:		0px 0px 10px rgba(0,0,0,.2);
                box-shadow:	        0px 0px 10px rgba(0,0,0,.2);
                }
        .mobile-phone { position:fixed; bottom:0; left:0;  width:50%; height:60px; 
                font-size:13px;
                line-height: 150%;
                letter-spacing: 0;
                text-align: center;
                padding-top:10px;
                background: url("../images/parts/white.jpg") repeat;
                box-sizing: border-box;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-phone a {
                background: url("../images/parts/white.jpg") repeat;
                display: block;
                width:100%;
                height: 100%;
                }
        .mobile-order {
                position: fixed;
                text-align: center;
                bottom:0;
                right:0;
                width:50%;
                height: 60px;
                letter-spacing: 0;
                font-size:13px;
                z-index: 99999;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-order a {
                width:100%;
                height:60px;
                box-sizing: border-box;
                text-align: center;
                line-height: 200%;
                font-weight:500;
                letter-spacing: 0;
                padding-top:18px;
                display:block;
                color:#FFF;
                background: url("../images/parts/red.jpg") left top repeat;
                overflow: hidden;
                white-space: nowrap;
                text-decoration:none !important;
                position: relative;
                z-index: 1;
                -webkit-transition: all .3s ease;
                -moz-transition: all .3s ease;
                -ms-transition: all .3s ease;
                -o-transition: all .3s ease;
                transition: all .3s ease;
                }
                .mobile-order a:hover {
                opacity:1;
                filter: alpha(opacity=100);
                -ms-filter: "alpha( opacity=100 )";
                color:#FFF;
                }

        }



/*==================================================================================================

       フッター

===================================================================================================*/

footer {
        width:100%;
        position: relative;
        background: url("../images/parts/footer-bg.jpg") center center / cover;
        font-size:.94117647rem;
        line-height: 200%;
        z-index: 10;
        color:#FFF;
        }
    
        .footer-logo {
        width:100%;
        max-width:145px;
        margin-bottom:1rem;
        position: relative;
        }
        @media only screen and (max-width: 1024px) {
        .footer-logo { width:150px; }
        }
        @media only screen and (max-width: 767px) {
        .footer-logo { width:180px; margin: 2rem auto 0; }
        }

.footer-menu {
        width:100%;
        text-align:center;
        }
        .footer-menu li {
        display: inline-block;
        font-size:1rem;
        padding:.25rem 15px .125rem;
        }
        .footer-menu li a {
        font-size:1rem;
        color:#FFF;
        position: relative;
        display: inline-block;
        text-decoration: none;
        }
        .footer-menu li a:hover {
        cursor: pointer;
        opacity: .6;
        text-decoration: none;
        }
        .footer-menu li a::after {
        position: absolute;
        bottom: 0px;
        left: 0;
        content: '';
        width: 100%;
        height: 1px;
        background: #FFF;
        transform: scale(0, 1);
        transform-origin: right top;
        transition: transform .3s;
        }
        .footer-menu li a:hover::after {
        transform-origin: left top;
        transform: scale(1, 1);
        }

.copyright {
        position: relative;
        z-index: 100;
        letter-spacing:0;
        box-sizing: border-box;
        color:#FFF;
        width:100%;
        font-size:13px;
        }
        .copyright img { vertical-align: middle; }

        @media only screen and (max-width: 767px) {
        .footer-nav { display:none; }
        .footer-menu { border-top:1px solid rgba(255,255,255,.3); }
        .footer-menu.top-line-none { border-top:none; }
        .footer-menu li { display: block; width:100%; text-align: center; border-bottom:1px solid rgba(255,255,255,.3); padding:0; }
        .footer-menu li:last-child {  }
        .footer-menu li a { padding:.75rem 1rem; display: block; }
        .footer-menu li a:before { display:none; }
        .footer-menu li:before {  display:none ;}

        .copyright { padding:0 0 6rem 0; text-align: center;font-size:10px; }
        }

/*=================================================

		ページトップ

 ==================================================*/

#totop {
        display:none;
        *display:block; /* IE 7 and below */
        position:fixed;
        bottom:20px;
        right:20px;
        z-index:999;
        }
        :root *> #totop { display:none;	}
        #totop { display:block; }
        *+html #totop { display:block; }
        #totop.open { display:block; }
        a.totop {
        width:50px;
        height:40px;
        padding-top:60px;
        display:block;
        cursor:pointer;
        text-align: center;
        color:#777;
        font-family: 'Poppins', sans-serif;
        font-size:13px;
        font-weight:500;
        line-height: 100%;
        position: relative;
        -webkit-transition: all .3s ease;
        -moz-transition: all .3s ease;
        -ms-transition: all .3s ease;
        -o-transition: all .3s ease;
        transition: all .3s ease;
        }
        a.totop:before {
        content:"";
        display:block;
        position: absolute;
        top:0;
        left:50%;
        margin-left:-1px;
        width:2px;
        height:50px;
        background:#777;
        z-index: 1;
        -webkit-transition: all .3s ease;
        -moz-transition: all .3s ease;
        -ms-transition: all .3s ease;
        -o-transition: all .3s ease;
        transition: all .3s ease;
        }
        a.totop:hover{ padding-top:70px;  }
        a.totop:hover:before { height:60px;  }
        @media only screen and (max-width: 767px) {
        a.totop p { display: block; }
        #totop { bottom:20px; right:5px;}
        a.totop{ font-size:10px; padding-top:40px; }
        a.totop:before { height:30px; }
        a.totop:hover{ padding-top:50px; }
        a.totop:hover:before { height:40px; }
        }