/* ===== Kikko - Cafe ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --beige:#f5f0e8;--beige-dark:#ebe4d6;
  --brown:#5c4033;--brown-light:#8b6f4e;--brown-dark:#3e2a1e;
  --green:#6b7c5e;--green-light:#8fa47b;
  --cream:#faf8f4;
  --text:#3e2a1e;--text-light:#7a6b5d;
  --white:#ffffff;
  --radius:16px;
}
html{scroll-behavior:smooth}
body{font-family:'Zen Maru Gothic',sans-serif;color:var(--text);line-height:1.8;background:var(--cream)}
a{color:inherit;text-decoration:none}
ul,dl{list-style:none}

.container{max-width:960px;margin:0 auto;padding:0 24px}

/* Fade-in animation */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* Header */
.header{position:fixed;top:0;left:0;right:0;background:rgba(250,248,244,.9);backdrop-filter:blur(10px);z-index:100;border-bottom:1px solid rgba(92,64,51,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:960px;margin:0 auto;padding:0 24px;height:60px}
.logo{font-size:1.4rem;font-weight:700;color:var(--brown);letter-spacing:.08em}
.nav-list{display:flex;gap:28px;font-size:.9rem;font-weight:500;color:var(--brown-light)}
.nav-list a:hover{color:var(--brown)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:var(--brown);transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero */
.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1445116572660-236099ec97a0?w=1400&h=900&fit=crop') center/cover no-repeat;z-index:0}
.hero-bg::before{content:'';position:absolute;inset:0;background:rgba(62,42,30,.35)}
.hero-content{position:relative;z-index:1;text-align:center;padding:0 24px}
.hero-sub-top{font-size:.9rem;color:rgba(255,255,255,.85);letter-spacing:.2em;margin-bottom:16px;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hero-title{font-size:4rem;font-weight:700;color:var(--white);letter-spacing:.12em;margin-bottom:16px;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.hero-sub{font-size:1.1rem;color:rgba(255,255,255,.9);letter-spacing:.08em;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,.6);animation:scrollLine 2s ease-in-out infinite}
.scroll-text{font-size:.7rem;color:rgba(255,255,255,.7);letter-spacing:.15em}
@keyframes scrollLine{0%,100%{opacity:.3;transform:scaleY(.5)}50%{opacity:1;transform:scaleY(1)}}

/* Sections */
.section{padding:100px 0}
.section-beige{background:var(--beige)}
.section-title{font-size:1.8rem;font-weight:700;text-align:center;margin-bottom:48px;letter-spacing:.1em;color:var(--brown)}

/* Concept */
.concept{text-align:center;max-width:480px;margin:0 auto}
.concept-text{font-size:1.05rem;line-height:2.2;color:var(--brown-light)}

/* Menu */
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.menu-cat-title{font-size:1.1rem;font-weight:700;letter-spacing:.1em;margin-bottom:20px;color:var(--green);text-align:center}
.menu-item{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.menu-item-visual{width:56px;height:56px;border-radius:50%;flex-shrink:0}
.drink-1{background:url('https://images.unsplash.com/photo-1495474472287-4d71bcdd2085?w=120&h=120&fit=crop') center/cover}
.drink-2{background:url('https://images.unsplash.com/photo-1509042239860-f550ce710b93?w=120&h=120&fit=crop') center/cover}
.drink-3{background:url('https://images.unsplash.com/photo-1515823064-d6e0c04616a7?w=120&h=120&fit=crop') center/cover}
.drink-4{background:url('https://images.unsplash.com/photo-1557006021-b85faa2bc5e2?w=120&h=120&fit=crop') center/cover}
.drink-5{background:url('https://images.unsplash.com/photo-1621263764928-df1444c5e859?w=120&h=120&fit=crop') center/cover}
.food-1{background:url('https://images.unsplash.com/photo-1488477181946-6428a0291777?w=120&h=120&fit=crop') center/cover}
.food-2{background:url('https://images.unsplash.com/photo-1578985545062-69928b1d9587?w=120&h=120&fit=crop') center/cover}
.food-3{background:url('https://images.unsplash.com/photo-1484723091739-30a097e8f929?w=120&h=120&fit=crop') center/cover}
.food-4{background:url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=120&h=120&fit=crop') center/cover}
.menu-item-info{display:flex;justify-content:space-between;align-items:baseline;flex:1;border-bottom:1px dotted rgba(92,64,51,.2);padding-bottom:8px}
.menu-item-name{font-size:.95rem;font-weight:500}
.menu-item-price{font-size:.85rem;color:var(--brown-light)}
.menu-item-price::before{content:"\\"}
.menu-item-price::after{content:" (tax in)";font-size:.7rem}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-visual{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden}
.about-img{width:100%;height:100%;background:url('https://images.unsplash.com/photo-1554118811-1e0d58224f24?w=600&h=450&fit=crop') center/cover;border-radius:var(--radius)}
.about-text h3{font-size:1.2rem;font-weight:700;margin-bottom:16px;color:var(--brown)}
.about-text p{font-size:.95rem;color:var(--text-light);margin-bottom:16px;line-height:1.9}
.about-info{margin-top:24px}
.about-info-item{display:flex;gap:16px;padding:8px 0;border-bottom:1px solid rgba(92,64,51,.08)}
.about-info-item dt{font-weight:700;font-size:.85rem;min-width:80px;color:var(--brown)}
.about-info-item dd{font-size:.85rem;color:var(--text-light)}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-item{aspect-ratio:1;border-radius:var(--radius);overflow:hidden}
.gallery-placeholder{width:100%;height:100%;transition:transform .4s ease}
.gallery-item:hover .gallery-placeholder{transform:scale(1.05)}
.g1{background:url('https://images.unsplash.com/photo-1517248135467-4c7edcad34c4?w=400&h=400&fit=crop') center/cover}
.g2{background:url('https://images.unsplash.com/photo-1442512595331-e89e73853f31?w=400&h=400&fit=crop') center/cover}
.g3{background:url('https://images.unsplash.com/photo-1563729784474-d77dbb933a9e?w=400&h=400&fit=crop') center/cover}
.g4{background:url('https://images.unsplash.com/photo-1600093463592-8e36ae95ef56?w=400&h=400&fit=crop') center/cover}
.g5{background:url('https://images.unsplash.com/photo-1461023058943-07fcbe16d735?w=400&h=400&fit=crop') center/cover}
.g6{background:url('https://images.unsplash.com/photo-1493857671505-72967e2e2760?w=400&h=400&fit=crop') center/cover}

/* Access */
.access-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.access-map{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;position:relative}
.map-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#d8e8d0,#c0d8b0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.map-pin{font-size:2.5rem}
.map-label{font-size:.85rem;font-weight:700;color:var(--green);letter-spacing:.1em}
.access-item{padding:12px 0;border-bottom:1px solid rgba(92,64,51,.08)}
.access-item dt{font-weight:700;font-size:.85rem;color:var(--brown);margin-bottom:4px}
.access-item dd{font-size:.9rem;color:var(--text-light);line-height:1.7}

/* Footer */
.footer{background:var(--brown-dark);color:var(--beige);padding:48px 0 24px}
.footer-inner{text-align:center;margin-bottom:32px}
.footer-logo{font-size:1.4rem;font-weight:700;letter-spacing:.1em;margin-bottom:4px;color:var(--white)}
.footer-tagline{font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:16px}
.footer-sns{display:flex;justify-content:center;gap:12px}
.footer-sns a{color:rgba(255,255,255,.6);transition:color .2s}
.footer-sns a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.75rem;color:rgba(255,255,255,.4);line-height:1.8}
.footer-note{margin-top:8px;font-size:.7rem}
.footer-copy{margin-top:8px}

/* Responsive */
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-list{
    display:none;flex-direction:column;position:absolute;top:60px;left:0;right:0;
    background:rgba(250,248,244,.98);padding:16px 24px;gap:12px;
    border-bottom:1px solid rgba(92,64,51,.08)
  }
  .nav-list.open{display:flex}
  .hero-title{font-size:2.5rem}
  .menu-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .access-content{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:64px 0}
}
@media(max-width:480px){
  .hero-title{font-size:2rem}
  .gallery-grid{grid-template-columns:1fr 1fr}
}
