/*
Theme Name: MAK Theme
Theme URI: https://mak-bar.jp
Author: 株式会社ii
Description: Majikuso tanoshii bar — MAK 公式サイトテーマ
Version: 1.0.0
Text Domain: mak-theme
*/

@import url('https://fonts.googleapis.com/css2?family=Dela+Gothic+One&family=Boogaloo&family=Noto+Sans+JP:wght@400;700;900&family=Share+Tech+Mono&display=swap');

:root {
  --red:#E53935; --red-d:#B71C1C; --red-l:#F9A8A8;
  --yel:#FFD600; --yel-d:#F9A825; --yel-l:#FFF176;
  --kinari:#FFF59D; --kinari-d:#FFD600;
  --brown:#5C3A1E; --brown-l:#8B6347;
  --white:#FFFDE7; --black:#1A0A00;
  --bg-alt:#FFE800;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--kinari);color:var(--brown);overflow-x:hidden;}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:200;background:var(--red);border-bottom:3px solid var(--red-d);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;box-shadow:0 3px 12px rgba(169,28,28,.35);gap:8px;}
.logo{font-family:'Boogaloo',cursive;font-size:16px;color:var(--yel);text-decoration:none;letter-spacing:.04em;text-shadow:1px 1px 0 var(--red-d);flex-shrink:0;line-height:1;white-space:nowrap;}
nav{display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:1;min-width:0;}
nav::-webkit-scrollbar{display:none;}
nav ul{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;list-style:none;margin:0;padding:0;gap:0;}
nav ul li{display:block;flex-shrink:0;}
nav a,nav ul li a{color:rgba(255,248,200,.85);text-decoration:none;font-size:11px;padding:5px 8px;border-radius:14px;transition:.2s;white-space:nowrap;display:block;}
nav a:hover,nav a.current-menu-item,nav ul li a:hover,nav ul li.current-menu-item>a{color:var(--yel);background:rgba(255,214,0,.18);}
.nav-cta{background:var(--yel)!important;color:var(--red-d)!important;font-weight:900!important;padding:6px 12px!important;border-radius:14px;margin-left:4px;box-shadow:2px 2px 0 var(--red-d);font-size:11px!important;flex-shrink:0;white-space:nowrap;}
.nav-cta:hover{background:var(--yel-l)!important;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--yel);border-radius:2px;}
.mobile-nav{display:none;position:fixed;top:60px;left:0;right:0;background:var(--red);border-bottom:2px solid var(--red-d);padding:12px 16px;flex-direction:column;gap:2px;z-index:199;}
.mobile-nav a{color:rgba(255,248,200,.9);text-decoration:none;font-size:15px;padding:11px 14px;border-radius:8px;display:block;transition:.2s;}
.mobile-nav a:hover{background:rgba(255,214,0,.15);color:var(--yel);}
.mobile-nav.open{display:flex;}

/* PAGE HERO */
.page-hero{margin-top:60px;padding:72px 24px 56px;background:var(--red);background-image:radial-gradient(circle,rgba(255,214,0,.15) 2px,transparent 2px);background-size:24px 24px;text-align:center;position:relative;overflow:hidden;}
.page-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:40px;background:var(--kinari);clip-path:polygon(0 100%,100% 100%,100% 0);}
.page-hero .eyebrow{font-family:'Boogaloo',cursive;font-size:13px;letter-spacing:.22em;color:var(--yel-l);display:block;margin-bottom:8px;}
.page-hero h1{font-family:'Noto Sans JP',sans-serif;font-weight:900;font-size:clamp(32px,6vw,56px);color:var(--yel);text-shadow:2px 2px 0 var(--red-d);letter-spacing:-.01em;}
.page-hero p{font-size:14px;color:rgba(255,248,200,.8);margin-top:10px;}

/* SECTION COMMON */
.sec-inner{max-width:1060px;margin:0 auto;padding:80px 24px;}
.sec-eyebrow{font-family:'Boogaloo',cursive;font-size:13px;letter-spacing:.22em;color:var(--red);display:block;margin-bottom:8px;}
.sec-title{font-family:'Noto Sans JP',sans-serif;font-weight:900;font-size:clamp(24px,4vw,42px);line-height:1.2;margin-bottom:44px;color:var(--brown);letter-spacing:.01em;text-align:center;}
.sec-title em{color:var(--red);font-style:normal;}
.sec-eyebrow{font-family:'Boogaloo',cursive;font-size:13px;letter-spacing:.22em;color:var(--red);display:block;margin-bottom:8px;text-align:left;}

/* SLANT */
.slant-to-alt{display:block;height:56px;background:var(--bg-alt);clip-path:polygon(0 0,100% 0,100% 100%,0 60%);}
.slant-to-main{display:block;height:56px;background:var(--kinari);clip-path:polygon(0 0,100% 40%,100% 100%,0 100%);}
.slant-to-red{display:block;height:56px;background:var(--red);clip-path:polygon(0 0,100% 0,100% 60%,0 100%);}
.slant-from-red{display:block;height:56px;background:var(--kinari);clip-path:polygon(0 0,100% 40%,100% 100%,0 100%);}

/* BUTTONS */
.btn-red{background:var(--red);color:var(--yel);font-family:'Dela Gothic One',cursive;font-size:15px;padding:13px 32px;border-radius:50px;text-decoration:none;display:inline-block;box-shadow:3px 3px 0 var(--red-d);transition:.18s;border:none;cursor:pointer;}
.btn-red:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--red-d);}
.btn-yel{background:var(--yel);color:var(--red-d);font-family:'Dela Gothic One',cursive;font-size:15px;padding:13px 32px;border-radius:50px;text-decoration:none;display:inline-block;box-shadow:3px 3px 0 var(--yel-d);transition:.18s;border:none;cursor:pointer;}
.btn-yel:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--yel-d);}
.btn-outline{background:transparent;color:var(--red);font-family:'Dela Gothic One',cursive;font-size:15px;padding:13px 32px;border-radius:50px;border:2px solid var(--red);text-decoration:none;display:inline-block;transition:.18s;}
.btn-outline:hover{background:var(--red);color:var(--yel);}
.btn-outline-w{background:transparent;color:var(--yel);font-family:'Dela Gothic One',cursive;font-size:15px;padding:13px 32px;border-radius:50px;border:2px solid var(--yel);text-decoration:none;display:inline-block;transition:.18s;}
.btn-outline-w:hover{background:var(--yel);color:var(--red-d);}

/* SNS */
.sns-row{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}
.sns-btn{padding:10px 18px;border-radius:12px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:.2s;line-height:1;}
.sns-btn:hover{transform:translateY(-3px);opacity:.92;}
.sns-ig{background:linear-gradient(45deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);color:#fff;box-shadow:0 3px 10px rgba(220,39,67,.35);}
.sns-tt{background:#010101;color:#fff;border:1.5px solid #2a2a2a;box-shadow:0 3px 10px rgba(0,0,0,.3);}

/* FOOTER */
footer{background:#B71C1C;color:var(--kinari-d);padding:52px 24px 28px;}
.footer-inner{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:36px;}
.footer-logo{font-family:'Dela Gothic One',cursive;font-size:28px;color:var(--yel);display:block;text-decoration:none;margin-bottom:10px;text-shadow:2px 2px 0 rgba(0,0,0,.3);}
.footer-logo small{display:block;font-size:9px;color:rgba(255,246,195,.65);letter-spacing:.12em;font-family:'Boogaloo',cursive;}
.footer-brand p{font-size:12px;line-height:1.9;color:rgba(255,240,185,.6);}
.footer-col h4{font-family:'Dela Gothic One',cursive;font-size:12px;color:var(--yel-l);letter-spacing:.1em;margin-bottom:12px;}
.footer-col a{display:block;color:rgba(255,240,185,.65);text-decoration:none;font-size:13px;padding:4px 0;transition:.2s;border-bottom:1px solid rgba(255,255,255,.05);}
.footer-col a:hover{color:var(--yel);padding-left:5px;}
.footer-bottom{max-width:1060px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-bottom p{font-size:11px;color:rgba(255,240,185,.35);}
.footer-bottom-links{display:flex;gap:14px;}
.footer-bottom-links a{font-size:11px;color:rgba(255,240,185,.4);text-decoration:none;transition:.2s;}
.footer-bottom-links a:hover{color:var(--yel);}

/* REVEAL */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease;}
.reveal.visible{opacity:1;transform:none;}

/* FORMS */
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:12px;font-weight:700;color:var(--red);letter-spacing:.06em;margin-bottom:6px;}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--white);border:2px solid var(--kinari-d);border-radius:10px;padding:11px 14px;font-size:14px;color:var(--brown);font-family:'Noto Sans JP',sans-serif;outline:none;transition:.2s;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red);}
.form-group textarea{resize:vertical;min-height:110px;}
.form-req{color:var(--red);margin-left:3px;}
.form-note{font-size:11px;color:var(--brown-l);margin-bottom:18px;line-height:1.7;}

/* RESPONSIVE */
@media(max-width:768px){
  header{padding:0 16px;}
  nav{display:none;}
  .hamburger{display:flex;}
  .footer-inner{grid-template-columns:1fr;gap:24px;}
  .footer-bottom{flex-direction:column;align-items:flex-start;}
  .sec-inner{padding:60px 18px;}
}

/* ==============================
   フローティングLINEボタン（常時右下表示）
   ============================== */
.floating-line{
  position:fixed;
  bottom:24px;
  right:20px;
  z-index:9999;
  display:flex;
  align-items:center;
  gap:8px;
  background:#06C755;
  color:#fff;
  font-family:'Noto Sans JP',sans-serif;
  font-weight:700;
  font-size:13px;
  padding:12px 18px;
  border-radius:40px;
  text-decoration:none;
  border:3px solid #3D0A05;
  box-shadow:4px 4px 0 #3D0A05;
  transition:.2s;
  white-space:nowrap;
}
.floating-line:hover{
  transform:translate(-2px,-2px);
  box-shadow:6px 6px 0 #3D0A05;
}
.floating-line-badge{
  background:#fff;
  color:#06C755;
  font-weight:900;
  font-size:11px;
  padding:1px 5px;
  border-radius:3px;
  letter-spacing:.05em;
  flex-shrink:0;
}
/* スマホでは文字を短くして小さめに */
@media(max-width:768px){
  .floating-line{
    font-size:12px;
    padding:10px 14px;
    bottom:16px;
    right:14px;
  }
}
