/****  COMMON CSS SETTINGS FOR ALL DEVICES ***/

/* GLOBAL PAGE SETTINGS */
* {margin: 0; padding: 0; box-sizing: border-box;}
:root { 
    --button-1: 10em; --button-2: 15em;--button-3: 20em;--button-4: 25em;
    --fs-1: 1rem; --fs-2: 2rem; --fs-3: 3rem; --fs-4: 4rem;
    --height-1: 2dvh; --height-2: 4dvh; -height-3: 6dvh; --height-4: 8dvh;
    --margin-1: 1dvw; --margin-2: 2dvw; --margin-3: 6dvw; --margin-4: 8dvw;
    --padding-1: 2dvw; --padding-2: 4dvw; --padding-3: 6dvw; --padding-4: 8dvw;
    --width-1: 2dvw; --width-2: 4dvw; --width-3: 6dvw; --width-4: 8dvw;--width-5: 10dvw;--width-6: 12dvw;
    --s: .5dvw; --c:darkgrey 70% 35%; --d: blue;
    --main-color: red; --secondary-color: lightgreen;  --txt-color: aliceblue; 
    --img-bg-color: rgba(240, 240, 240, 0.9);
}
body {font-family: system-ui, apple-system, sans-serif; color:#333; margin: 0; padding: 0; box-sizing: border-box; overscroll-behavior-y: contain; }   
   
/* container general settings */
#container{position: relative; box-sizing: border-box; display: grid; grid-template-columns: repeat(auto-fit, minmax(auto-fill, 1fr)); grid-auto-rows: minmax(3dvh, auto); grid-auto-flow: column; max-width: 200rem; width: 100%; height: auto; margin-inline: auto ; overflow: auto; will-change: scroll-position; outline: 1dvw solid lightgreen; }
#container{container-type: inline-size; container-name: parent;}

/* container and grid settings */
#heading{grid-column: 1/5; grid-row:1/2;}
.info{grid-column: 1/5; grid-row: 2/3;}
section{grid-column:1/5; grid-row:3/4;} 
footer{grid-column: 1/5; grid-row: 4/5;}

/*** HEADING settings ***/
#heading{display: grid; grid-template-columns: 15rem 80rem; gap: 2rem; max-width: 200rem; width: 100%;  height: 18dvh; }
#heading{--s: .5dvw; --c: lightgrey; --_s: calc(2*var(--s)) calc(2*var(--s)); --_g: 35.36% 35.36% at; --_c: #0000 66%,black 40% 70%, #0000 72%; background: radial-gradient(var(--_g) 100% 25%,var(--_c)) var(--s) var(--s)/var(--_s), radial-gradient(var(--_g) 0 75%,var(--_c)) var(--s) var(--s)/var(--_s),  radial-gradient(var(--_g) 100% 25%,var(--_c)) 0 0/var(--_s), radial-gradient(var(--_g) 0 75%,var(--_c)) 0 0/var(--_s), repeating-conic-gradient(var(--c) 0 25%,#0000 0 50%) 0 0/var(--_s), radial-gradient(var(--_c)) 0 calc(var(--s)/2)/var(--s) var(--s) var(--c); }
/* formatting language */
#language {position: fixed; max-width: 5%; width: 100%; height: 7dvh; display: flex; flex-flow: column nowrap; z-index: 1111;}
#language input{font-size: var(--fs-1); color: white; background-color: black; border: 0.1dvw solid black; line-height: 1;  padding-left: calc(var(--padding-1)*0.6); margin-block:0.3dvw;cursor: pointer; border-radius: 2dvw; }
#language input[class="chinese"]:not(h1){font-size: var(--fs-1);line-height: 1.5; letter-spacing: 0.01dvw; font-family: 松本，微软雅黑, Helvetica, sans-serif; }
/* navigation section formatting*/
#menu button{position: fixed; max-width: 5%; width: 100%; height: 2dvw; background:skyblue; opacity:1; color:white; box-shadow:inset 0 0 0 1px black; border:0.3dvw solid white; display: flex; justify-content: center; align-items: center; border-radius: 1dvw;}
#menu button{font-size: var(--fs-2); }
#menu button:hover{background:grey; color:aliceblue; box-shadow:inset 0 0 0 1px white; border:0.4dvw solid black; cursor: pointer;}  
/* formatting header */
header{ position: relative;max-width: 200rem; width: 100%;}
header h1{display: flex; flex-flow: row nowrap; justify-content: center; align-items: center;  width: 50dvw; margin-left: 5dvw; margin-top: 5%;color: blue; font-size: 3dvw; animation: infinite linear 30s styling; z-index: 99;}
@keyframes styling{
    0%{ translate: 0dvw 0dvw  1dvw; color: black; } 
    25%{ translate: -1dvw -.3dvw 2dvw; color:blue; }
    50%{ translate: 0dvw 0dvw 3dvw; color: red;} 
    75%{ translate: 1dvw .3dvw 2dvw; color: green; }
    100%{ translate: 0dvw 0dvw 1dvw; color: black;} 
} 

/* styling info section */
.info{display: flex; flex-flow: row nowrap; justify-content:flex-start;  max-width: 200rem; width: 100%;  margin-block: 0.5dvw; margin-inline: 1dvw; height:3dvh;}
.info .enlarge .text{color: black;  font-size: calc(var(--fs-1)*1.3); font-weight: 400;} 
.info .sum{width: 20dvw; margin-inline: 5dvw;}
.info .sum p{position: relative; max-width: 40dvw; width: 100%; font-size: calc(var(--fs-1)*1.3); margin-left: 10dvw; }
.info .sum p a{margin-left: 0.5dvw; color: orangered;}

/* formatting the lw-container main section*/
.lw-container {position:relative; max-width: 200rem; width: 99%; margin-left: -1%; margin: 0 auto;} 
.lw-box {display: inline-grid; grid-template-columns: repeat(7, 1fr); grid-auto-rows: minmax(8dvh, auto); grid-gap: 0.25dvw; max-width: 200rem; width: 100%;position: relative; margin-left: -1dvw; counter-reset: image-number;} 
.lw-box .city{position: relative; display: flex; justify-content: center; align-items: center; width: 70%; height: 40%; color: rgb(207, 213, 29); font-size: var(--fs-2); background-color: grey; margin-block: 30%; margin-inline: 20%; border-radius: 2dvw;}
.lw-box .gallery-item:not(.city){width: 100%; height: 35dvh; margin-inline: 1dvw; counter-increment: image-number;}
.lw-box .gallery-item:not(.city)::before{ content: counter(image-number); position: relative; top: 5%; right: -1%; width: max-content;  background: aqua;  padding: 0.2dvw 0.4dvw; font-weight: normal; border-radius: 0.5dvw; z-index: 1;}
.lw-box .gallery-item p:not(.overlay p){text-transform: uppercase; }
.lw-box .gallery-item img {object-fit: fill; object-position: top; cursor: pointer; max-width: 100%; width: 20dvw; height: 30vh; border-radius:1dvw; }
.lw-box .gallery-item img:hover {opacity: 0.8; scale:1.1; transition: 3s ease;} 
.lw-box .gallery-item .overlay{width: 100%; max-width: 22dvw; margin-inline: -1dvw;}
.lw-box .overlay p{display: flex; justify-content: center; align-items: center; color: black; background-color: aquamarine; font-size: calc(var(--fs-1)*1.2); height: auto;  width: 100%; max-width: 22dvw; border-radius: 1dvw; margin-inline: 1dvw;} 
#lw-screen { position: fixed; width: 100%; height: 100%;  top: 1dvw; left: 1dvw; overflow: hidden; background: var(--backdrop-color); z-index: 9999;  text-align: center; }
#lw-screen .lw-image {height: 100%; display: inline-flex; justify-content: center; align-items: center;scale: 1.1;}
#lw-screen .lw-image img {max-width: 100%; max-height:100%; margin-block: 0dvw; margin-inline: 0dvw; transition: 5s ease;border-radius: 1dvw;}
#lw-screen.dragging{cursor: grabbing;}
.lw-btn {width: 3dvw; height: 3dvw; background: var(--main-color); color: var(--txt-color); text-align: center; line-height: 3dvw;  cursor: pointer; -moz-transition: all 0.4s ease; -o-transition: all 0.4s ease;  -webkit-transition: all 0.4s ease;  transition: all 0.4s ease; font-size: 2dvw; box-sizing: border-box;  position: fixed; bottom: 2dvw;}
.lw-btn:hover { background: var(--secondary-color); }
.lw-close {position: absolute; bottom:10dvw; right: 30dvw;}

/** SETTINGS FOR OTHER DEVICES AND OTHER SIZES**/

/*max-width: 107rem = 1,712px */
@media only screen and (96rem <= width <= 107rem){
   #language, #menu button{max-width: 9%;}
   #menu button{height: 5%;}
   #heading{height: 15dvh;}
   .lw-box{grid-template-columns: repeat(4, 1fr); }
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
   .gallery-item .overlay p{font-size:calc(var(--fs-1)*1);}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.9);}
}    

/*max-width: 96rem = 1,528px */
@media only screen and (85rem <= width <= 96rem){
   #language, #menu button{max-width: 10dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-3)*1.5); margin-top: 2%; margin-left: 15dvw;}
   .enlarge p, sum p{width: auto; font-size:calc(var(--fs-1)*1.2);margin-top: 2%;}
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
   .gallery-item .overlay p{font-size:calc(var(--fs-1)*1);}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.9);}
}
@container parent (85rem <= width <= 96rem){
   #heading{width: 95rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 95rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 93rem; height: auto; margin-inline: 2dvw;}
}

/* max-width: 85rem = 1,360px */
@media screen and (75rem <= width <= 85rem) {
   #language, #menu button{max-width: 10dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-3)*1.5); margin-top: 2%; margin-left: 15dvw;}
   .enlarge p, sum p{width: auto; font-size:calc(var(--fs-1)*1.2);margin-top: 2%;}
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
   .gallery-item .overlay p{font-size:calc(var(--fs-1)*1);}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.9);}
} 

@container parent (75rem <= width <= 85rem){
   #heading{width: 85rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 85rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 83rem; height: auto; margin-inline: 2dvw;}
}

/* max-width: 75rem = 1,200px */
@media screen and (65rem <= width <= 75rem) {
   #language, #menu button{max-width: 10dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-3)*1.5); margin-top: 2%; margin-left: 15dvw;}
   .info{width: 75rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*1);}
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
   .gallery-item .overlay p{font-size:calc(var(--fs-1)*1);}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.8);}
}

@container parent (65rem <= width <= 75rem){
   #heading{width: 75rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 75rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 73rem; height: auto; margin-inline: 2dvw;}
}

 /* max-width : 65rem  = 1,040px */
 @media screen and (55rem <= width <= 65rem) {   
   #language, #menu button{max-width: 10dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-2)*1.5); margin-top: 3%; margin-left: 15dvw;}
   .info{width: 75rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*1);}
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
   .gallery-item .overlay p{font-size:calc(var(--fs-1)*0.81);}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.8);}
}

@container parent (55rem <= width <= 65rem){
   #heading{width: 65rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 65rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 63rem; height: auto; margin-inline: 2dvw;}
}
 
/* max-width: 55rem =  880px */
 @media screen and (45rem <= width <= 55rem){
   #language, #menu button{max-width: 12dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-2)*1.5); margin-top: 3%; margin-left: 15dvw;}
   .info{width: 65rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*0.8);}
   .lw-box {grid-template-columns: repeat(4, 1fr); gap: 0.2dvw;}
    .gallery-item .overlay p{width: 20dvw; font-size:calc(var(--fs-1)*0.8); margin-left: 3dvw;}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.7);}
   .lw-box .city{font-size:calc(var(--fs-1)*1.1);}
 }

@container parent (45rem <= width <= 55rem){
   #heading{width: 55rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 55rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 53rem; height: auto; margin-inline: 2dvw;}
  
}

/* max-width: 45rem =  720px */
 @media screen and (35rem <= width <= 45rem){
   #language, #menu button{max-width: 13dvw;}
   #language input{font-size: calc(var(--fs-1)*0.9);}
   #menu button{height: 4dvh;font-size: calc(var(--fs-1)*1.1);}
   header h1{font-size: calc(var(--fs-2)*1.2); margin-top: 3%; margin-left: 15dvw;}
   .info{width: 65rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*0.7);}
   .lw-box {grid-template-columns: repeat(3, 1fr); gap: 0.2dvw;}
    .gallery-item .overlay p{width: 20dvw; font-size:calc(var(--fs-1)*0.7); margin-left: 3dvw;}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.7);}
   .lw-box .city{font-size:calc(var(--fs-1)*1);}
 }

@container parent (35rem <= width <= 45rem){
   #heading{width: 45rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 45rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 43rem; height: auto; margin-inline: 2dvw;}
}

/* max-width: 35rem =  560px */
 @media screen and (25rem <= width <= 35rem){
   #language, #menu button{max-width: 14dvw;}
   #language input{font-size: calc(var(--fs-1)*0.8);}
   #menu button{height: 4dvh;font-size: calc(var(--fs-1)*1);}
   header h1{font-size: calc(var(--fs-2)*1); margin-top: 3%; margin-left: 15dvw;}
   .info{width: 85rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*0.6);}
   .lw-box {grid-template-columns: repeat(3, 1fr); gap: 0.2dvw;}
   .lw-box .gallery-item {width: 25dvw; height: 25dvh;}
   .lw-box .gallery-item img {width: 25dvw; height:30dvh; }
   .lw-box .gallery-item .overlay{max-width: 100%; height: auto;}
   .lw-box .gallery-item .overlay p{width: 100%; max-width: 27dvw;font-size:calc(var(--fs-1)*0.8); }
   .gallery-item::before{font-size:calc(var(--fs-1)*0.6);}
   .lw-box .city{font-size:calc(var(--fs-1)*1); height: 20dvh;}
 }

@container parent (25rem <= width <= 35rem){
    #heading{width: 35rem; height: 6rem; margin-inline: 0dvw;}
   .info{width: 35rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 33rem; height: auto; margin-inline: 2dvw;}
}

/* max-width: 25rem =  400px */
 @media screen and (20rem <= width <= 25rem){
   #language, #menu button{max-width: 12dvw;}
   #language input{font-size: calc(var(--fs-1)*1);}
   #menu button{height: 6dvh;font-size: calc(var(--fs-1)*1.5);}
   header h1{font-size: calc(var(--fs-2)*1.5); margin-top: 3%; margin-left: 15dvw;}
   .info{width: 65rem; display: grid; grid-template-rows: 1fr 1fr; }
   .info .enlarge .text, .info .sum .total {font-size: calc(var(--fs-1)*0.8);}
   .lw-box {grid-template-columns: repeat(3, 1fr); gap: 0.2dvw;}
    .gallery-item .overlay p{width: 20dvw; font-size:calc(var(--fs-1)*0.8); margin-left: 3dvw;}
   .gallery-item::before{font-size:calc(var(--fs-1)*0.7);}
   .lw-box .city{font-size:calc(var(--fs-1)*1.1);}
 }

@container parent (20rem <= width <= 25rem){
    #heading{width: 25rem; height: 9rem; margin-inline: 0dvw;}
   .info{width: 25rem; height: 5rem; margin-inline: 2dvw;}
   .lw-container{width: 25rem; height: auto; margin-inline: 2dvw;}
}
 