/*
Theme Name: WWHITEBEARS
Theme URI: https://wwhitebears.com/
Author: WWHITEBEARS
Author URI: https://wwhitebears.com/
Description: 地方創生と食の輸出をテーマにしたオリジナルWordPressテーマ。Polylang対応、Three.js地球儀、Instagram連携。
Version: 1.5.2
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wwhitebears
Tags: custom-colors, custom-menu, featured-images, translation-ready
*/

/* ============ Reset / Base ============ */
:root{
  --c-bg:#0a1612;
  --c-bg2:#0f2a22;
  --c-line:#1f3a30;
  --c-text:#e9e6dc;
  --c-sub:#b8b3a3;
  --c-gold:#d4a847;
  --c-gold2:#c89a3a;
  --f-jp:"Noto Serif JP","Yu Mincho",serif;
  --f-en:"Cormorant Garamond","Times New Roman",serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--c-bg);color:var(--c-text);font-family:var(--f-jp);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.wwb-container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ============ Header ============ */
.wwb-header{position:sticky;top:0;z-index:100;background:rgba(10,22,18,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--c-line)}
.wwb-header__inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}
.wwb-logo{font-family:var(--f-en);font-size:22px;letter-spacing:2px;color:var(--c-gold);font-weight:700}
.wwb-nav{display:flex;gap:24px;font-size:14px}
.wwb-nav a{transition:color .2s}
.wwb-nav a:hover{color:var(--c-gold)}
.wwb-header__right{display:flex;align-items:center;gap:12px}
.wwb-lang{display:flex;gap:6px;font-size:12px;flex-wrap:wrap}
.wwb-lang a,.wwb-lang button{background:transparent;border:1px solid var(--c-line);color:var(--c-text);padding:4px 10px;border-radius:14px;cursor:pointer;font-size:12px;transition:.2s}
.wwb-lang a.is-active,.wwb-lang button.is-active,.wwb-lang .current-lang{background:var(--c-gold);color:#111;border-color:var(--c-gold)}
.wwb-lang a:hover,.wwb-lang button:hover{border-color:var(--c-gold)}
.wwb-btn-admin{background:var(--c-gold);color:#111;border:none;padding:8px 18px;border-radius:4px;cursor:pointer;font-weight:700;font-size:13px;transition:.2s}
.wwb-btn-admin:hover{background:var(--c-gold2)}
.wwb-burger{display:none;background:none;border:none;color:var(--c-text);font-size:24px;cursor:pointer}

/* ============ Hero ============ */
.wwb-hero{position:relative;height:88vh;min-height:600px;overflow:hidden}
.wwb-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.5)}
.wwb-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,18,.4) 0%,rgba(10,22,18,.7) 100%);pointer-events:none}
.wwb-hero__inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;max-width:1200px;margin:0 auto;padding:0 24px}
.wwb-hero__tag{color:var(--c-gold);letter-spacing:3px;font-size:12px;margin-bottom:24px}
.wwb-hero__title{font-size:clamp(40px,7vw,88px);font-weight:700;line-height:1.25;margin:0 0 16px;word-break:keep-all;overflow-wrap:break-word;line-break:strict}
.wwb-hero__sub{font-family:var(--f-en);font-style:italic;color:var(--c-gold);font-size:clamp(20px,2.5vw,32px);margin:0 0 24px}
.wwb-hero__lead{max-width:520px;color:var(--c-sub);margin:0 0 32px}
.wwb-hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.wwb-btn{display:inline-block;padding:14px 28px;border-radius:4px;font-size:14px;cursor:pointer;border:1px solid transparent;transition:.2s;text-align:center}
.wwb-btn--primary{background:var(--c-gold);color:#111;font-weight:700}
.wwb-btn--primary:hover{background:var(--c-gold2)}
.wwb-btn--ghost{background:transparent;color:var(--c-text);border-color:var(--c-text)}
.wwb-btn--ghost:hover{background:rgba(255,255,255,.08)}

/* ============ Marquee ============ */
.wwb-marquee{background:#000;border-block:1px solid var(--c-line);overflow:hidden;padding:14px 0}
.wwb-marquee__track{display:flex;gap:48px;animation:wwb-scroll 40s linear infinite;white-space:nowrap;color:var(--c-gold);font-size:13px;letter-spacing:2px}
@keyframes wwb-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============ Section common ============ */
.wwb-section{padding:120px 0;position:relative;overflow:hidden}
.wwb-section__num{position:absolute;top:40px;right:40px;font-family:var(--f-en);font-size:120px;color:rgba(255,255,255,.04);font-weight:700;line-height:1}
.wwb-section__label{display:flex;align-items:center;gap:12px;color:var(--c-gold);font-size:12px;letter-spacing:2px;margin:0 0 24px}
.wwb-section__label::before{content:"";width:40px;height:1px;background:var(--c-gold)}
.wwb-section__title{font-size:clamp(28px,4.5vw,52px);line-height:1.4;margin:0 0 32px;font-weight:700;word-break:keep-all;overflow-wrap:break-word;line-break:strict}
.wwb-section__title em{font-style:normal;color:var(--c-gold)}

/* ============ Mission（郷・スライドショー） ============ */
.wwb-mission{background:var(--c-bg2)}
.wwb-mission__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:center;position:relative;z-index:2}
.wwb-mission__visual{position:relative;height:520px;border-radius:4px;overflow:hidden;background:#000}
.wwb-mission__slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease,transform 8s ease}
.wwb-mission__slide.is-active{opacity:1;transform:scale(1.08)}
.wwb-mission__visual::after{content:"郷";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:clamp(160px,22vw,280px);font-weight:700;color:rgba(255,255,255,.12);pointer-events:none;font-family:var(--f-jp);text-shadow:0 4px 30px rgba(0,0,0,.6)}
.wwb-mission__features{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.wwb-feature{padding:16px 0;border-top:1px solid var(--c-line)}
.wwb-feature__head{display:flex;align-items:center;gap:8px;color:var(--c-gold);font-size:14px;font-weight:700;margin-bottom:6px}
.wwb-feature__desc{font-size:12px;color:var(--c-sub)}

/* ============ Real Food ============ */
.wwb-real{background:#0a1612;position:relative}
.wwb-real__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22}
.wwb-real__inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:end}
.wwb-real p{color:var(--c-sub);max-width:380px;margin-left:auto}

/* ============ Local Dining ============ */
.wwb-dining{background:var(--c-bg2);border-block:1px solid var(--c-line)}
.wwb-dining__inner{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:end}
.wwb-dining p{color:var(--c-sub);max-width:380px;margin-left:auto}

/* ============ Global（地球儀） ============ */
.wwb-global{background:#0a1612;position:relative}
.wwb-global__inner{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:center}
.wwb-globe{width:100%;aspect-ratio:1;max-width:520px;margin-inline:auto;position:relative}
.wwb-globe canvas{display:block;width:100%!important;height:100%!important}
.wwb-globe__fallback{position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;display:none}
.wwb-globe.is-fallback .wwb-globe__fallback{display:block}

/* ============ Steps ============ */
.wwb-steps{background:var(--c-bg2)}
.wwb-steps__lead{max-width:720px;color:var(--c-sub)}
.wwb-steps__list{display:grid;gap:0;margin-top:48px}
.wwb-step{display:grid;grid-template-columns:100px 1fr auto;gap:24px;align-items:center;padding:28px 0;border-top:1px solid var(--c-line)}
.wwb-step:last-child{border-bottom:1px solid var(--c-line)}
.wwb-step__num{font-family:var(--f-en);font-size:56px;color:var(--c-gold);font-weight:700;line-height:1}
.wwb-step__title{font-size:20px;font-weight:700;margin:0 0 4px}
.wwb-step__desc{color:var(--c-sub);font-size:14px;margin:0}
.wwb-step__arrow{font-size:28px;color:var(--c-gold)}

/* ============ Contact Form ============ */
.wwb-contact{background:#0a1612}
.wwb-form{max-width:640px;margin:0 auto;background:rgba(0,0,0,.3);border:1px solid var(--c-line);padding:40px;border-radius:4px}
.wwb-form__head{color:var(--c-gold);font-size:13px;letter-spacing:2px;margin-bottom:24px}
.wwb-form input,.wwb-form textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--c-line);color:var(--c-text);padding:14px 16px;border-radius:4px;font-size:14px;font-family:inherit;margin-bottom:12px}
.wwb-form input:focus,.wwb-form textarea:focus{outline:none;border-color:var(--c-gold)}
.wwb-form textarea{min-height:120px;resize:vertical}
.wwb-form__error{color:#ff7a7a;font-size:12px;margin:-8px 0 12px;display:none}
.wwb-form__error.is-show{display:block}
.wwb-form button[type=submit]{width:100%;background:var(--c-gold);color:#111;border:none;padding:16px;font-size:15px;font-weight:700;border-radius:4px;cursor:pointer;margin-top:8px;transition:.2s}
.wwb-form button[type=submit]:hover:not(:disabled){background:var(--c-gold2)}
.wwb-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}
.wwb-form__msg{margin-top:16px;font-size:13px;text-align:center;min-height:20px}
.wwb-form__msg.is-ok{color:#7ed3a1}
.wwb-form__msg.is-ng{color:#ff7a7a}
.wwb-form__note{font-size:11px;color:var(--c-sub);margin-top:16px;text-align:center}

/* ============ Instagram ============ */
.wwb-ig{background:var(--c-bg2);padding:80px 0;text-align:center}
.wwb-ig__head{color:var(--c-gold);font-size:13px;letter-spacing:2px;margin-bottom:8px}
.wwb-ig__handle{font-family:var(--f-en);font-size:32px;margin:0 0 4px}
.wwb-ig__follow{display:inline-block;color:var(--c-gold);font-size:12px;border-bottom:1px solid var(--c-gold);margin-bottom:32px;padding-bottom:2px}
.wwb-ig__grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;max-width:1200px;margin:0 auto;padding:0 24px}
.wwb-ig__item{aspect-ratio:1;background:#222;overflow:hidden;border-radius:2px;position:relative}
.wwb-ig__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.wwb-ig__item:hover img{transform:scale(1.08)}
.wwb-ig__more{display:inline-block;margin-top:24px;color:var(--c-gold);font-size:13px}

/* ============ Newsletter / Footer ============ */
.wwb-news{background:#0a1612;padding:80px 0;border-top:1px solid var(--c-line)}
.wwb-news__inner{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:60px;align-items:center}
.wwb-news h2{font-size:36px;line-height:1.5;margin:0;word-break:keep-all;overflow-wrap:break-word;line-break:strict}
.wwb-news h2 em{color:var(--c-gold);font-style:normal}
.wwb-news__form{display:flex;gap:8px}
.wwb-news__form input{flex:1;background:rgba(255,255,255,.05);border:1px solid var(--c-line);color:var(--c-text);padding:14px;border-radius:4px;font-family:inherit}
.wwb-news__form button{background:var(--c-gold);color:#111;border:none;padding:14px 24px;border-radius:4px;font-weight:700;cursor:pointer}
.wwb-footer{background:#000;padding:40px 0;text-align:center;color:var(--c-sub);font-size:12px;border-top:1px solid var(--c-line)}

/* ============ Admin Login Modal ============ */
.wwb-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.wwb-modal.is-open{display:flex}
.wwb-modal__box{background:#0f2a22;border:1px solid var(--c-gold);border-radius:8px;padding:40px;max-width:420px;width:100%;position:relative}
.wwb-modal__close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--c-text);font-size:24px;cursor:pointer}
.wwb-modal__title{color:var(--c-gold);font-size:20px;margin:0 0 4px}
.wwb-modal__sub{color:var(--c-sub);font-size:12px;letter-spacing:2px;margin:0 0 24px}
.wwb-modal input{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--c-line);color:var(--c-text);padding:12px 14px;border-radius:4px;margin-bottom:12px;font-family:inherit}
.wwb-modal button[type=submit]{width:100%;background:var(--c-gold);color:#111;border:none;padding:12px;font-weight:700;border-radius:4px;cursor:pointer}
.wwb-modal__note{color:var(--c-sub);font-size:11px;margin-top:16px;text-align:center}

/* ============ Responsive ============ */
@media (max-width:900px){
  .wwb-nav{display:none;position:absolute;top:72px;left:0;right:0;background:var(--c-bg2);flex-direction:column;padding:24px;border-bottom:1px solid var(--c-line)}
  .wwb-nav.is-open{display:flex}
  .wwb-burger{display:block}
  .wwb-hero{height:auto;min-height:auto;padding:80px 0 60px}
  .wwb-section{padding:80px 0}
  .wwb-mission__grid,.wwb-real__inner,.wwb-dining__inner,.wwb-global__inner,.wwb-news__inner{grid-template-columns:1fr;gap:32px}
  .wwb-mission__visual{height:320px}
  .wwb-mission__features{grid-template-columns:1fr}
  .wwb-real p,.wwb-dining p{margin-left:0;max-width:none}
  .wwb-step{grid-template-columns:70px 1fr;gap:12px}
  .wwb-step__num{font-size:40px}
  .wwb-step__arrow{display:none}
  .wwb-ig__grid{grid-template-columns:repeat(4,1fr)}
  .wwb-section__num{font-size:60px;top:20px;right:20px}
  .wwb-form{padding:24px}
  .wwb-header__right .wwb-lang{display:none}
}
@media (max-width:480px){
  .wwb-ig__grid{grid-template-columns:repeat(2,1fr)}
  .wwb-news__form{flex-direction:column}
}

/* ============ Archive / Single (CPT common) ============ */
.wwb-archive{padding:120px 0 80px;min-height:60vh}
.wwb-archive__head{text-align:center;margin-bottom:60px}
.wwb-archive__title{font-size:clamp(32px,5vw,56px);margin:8px 0 16px;font-weight:700}
.wwb-archive__lead{color:var(--c-sub);max-width:640px;margin:0 auto}
.wwb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.wwb-card{display:block;background:var(--c-bg2);border:1px solid var(--c-line);border-radius:6px;overflow:hidden;transition:.3s;color:inherit}
.wwb-card:hover{transform:translateY(-4px);border-color:var(--c-gold);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.wwb-card__thumb{aspect-ratio:4/3;background:#111;overflow:hidden;position:relative}
.wwb-card__thumb img{width:100%;height:100%;object-fit:cover}
.wwb-card__noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--c-sub);font-family:var(--f-en);letter-spacing:2px;font-size:14px}
.wwb-card__body{padding:24px}
.wwb-card__meta{color:var(--c-gold);font-size:11px;letter-spacing:1px;margin-bottom:8px}
.wwb-card__meta a{text-decoration:none}
.wwb-card__title{font-size:20px;margin:0 0 8px;font-weight:700;line-height:1.4}
.wwb-card__excerpt{font-size:13px;color:var(--c-sub);margin:0;line-height:1.6}
.wwb-pagination{display:flex;justify-content:center;margin-top:60px}
.wwb-pagination .page-numbers{padding:10px 16px;border:1px solid var(--c-line);border-radius:4px;color:var(--c-text);margin:0 4px;text-decoration:none}
.wwb-pagination .current{background:var(--c-gold);color:#111;border-color:var(--c-gold)}

.wwb-single{padding:120px 0 80px;max-width:820px;min-height:60vh}
.wwb-single__title{font-size:clamp(28px,4vw,42px);margin:12px 0 16px;font-weight:700;line-height:1.3}
.wwb-single__meta{color:var(--c-sub);font-size:12px;margin-bottom:24px}
.wwb-single__meta a{color:var(--c-gold);text-decoration:none}
.wwb-single__thumb{margin:24px 0;border-radius:6px;overflow:hidden}
.wwb-entry-content{line-height:1.9;font-size:16px}
.wwb-entry-content h2{font-size:24px;margin:40px 0 16px;padding-bottom:8px;border-bottom:1px solid var(--c-line)}
.wwb-entry-content h3{font-size:20px;margin:32px 0 12px}
.wwb-entry-content p{margin:0 0 18px}
.wwb-entry-content a{color:var(--c-gold);text-decoration:underline}
.wwb-entry-content img{border-radius:4px;margin:16px 0}
.wwb-entry-content ul,.wwb-entry-content ol{padding-left:24px;margin:0 0 18px}
.wwb-entry-content blockquote{border-left:3px solid var(--c-gold);padding:8px 20px;margin:20px 0;color:var(--c-sub);font-style:italic}

@media (max-width:900px){
  .wwb-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .wwb-archive{padding:80px 0 60px}
  .wwb-single{padding:80px 0 60px}
}
@media (max-width:560px){
  .wwb-grid{grid-template-columns:1fr}
}

/* ============ Booking / Experience ============ */
.wwb-notice{background:var(--c-bg2);border:1px solid var(--c-line);padding:40px;border-radius:6px;text-align:center;color:var(--c-sub);margin:40px 0}
.wwb-notice strong{color:var(--c-gold)}

.wwb-exp-card .wwb-card__body{padding:24px}
.wwb-exp-card__foot{display:flex;gap:16px;flex-wrap:wrap;font-size:11px;color:var(--c-sub);margin-top:12px}
.wwb-exp-card__price{margin-top:16px;padding-top:16px;border-top:1px solid var(--c-line);font-size:20px;color:var(--c-gold);font-weight:700}
.wwb-exp-card__price .wwb-exp-card__per{font-size:11px;color:var(--c-sub);margin-left:8px;font-weight:400}
.wwb-exp-card__price .woocommerce-Price-amount{color:var(--c-gold)}

/* Booking form on single product */
.wwb-booking{background:rgba(0,0,0,.25);border:1px solid var(--c-line);padding:24px;border-radius:6px;margin:24px 0}
.wwb-booking__title{color:var(--c-gold);font-size:16px;margin:0 0 16px;font-weight:700}
.wwb-booking__row{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:center;margin-bottom:12px}
.wwb-booking__row label{font-size:13px;color:var(--c-sub)}
.wwb-booking__row input,.wwb-booking__row select,.wwb-booking__row textarea{
  width:100%;background:rgba(255,255,255,.05);border:1px solid var(--c-line);
  color:var(--c-text);padding:10px 12px;border-radius:4px;font-size:14px;font-family:inherit
}
.wwb-booking__row input:focus,.wwb-booking__row select:focus,.wwb-booking__row textarea:focus{outline:none;border-color:var(--c-gold)}
.wwb-booking__total{margin-top:16px;padding-top:16px;border-top:1px solid var(--c-line);text-align:right;font-size:18px;color:var(--c-text)}
.wwb-booking__total #wwb-total{color:var(--c-gold);font-weight:700;font-size:24px;margin-left:8px}

/* WooCommerce common style adapt */
.woocommerce .wwb-container{padding-block:80px}
body.woocommerce-page,body.woocommerce{background:var(--c-bg);color:var(--c-text)}
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price{color:var(--c-gold)!important}
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce button.button.alt,
.woocommerce .single_add_to_cart_button{
  background:var(--c-gold)!important;color:#111!important;
  font-weight:700;border-radius:4px;padding:14px 28px;border:none
}
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover{background:var(--c-gold2)!important}
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  background:var(--c-bg2);border-top:3px solid var(--c-gold);color:var(--c-text)
}
.woocommerce-message::before,.woocommerce-info::before{color:var(--c-gold)}

@media (max-width:560px){
  .wwb-booking__row{grid-template-columns:1fr;gap:6px}
}

/* ============ Shop (Real Food) ============ */
.wwb-shop-grid .wwb-shop-card .wwb-card__thumb{aspect-ratio:1/1}
.wwb-shop-card__cta{margin-top:16px;color:var(--c-gold);font-size:13px;font-weight:700;letter-spacing:1px}
.wwb-shop-card:hover .wwb-shop-card__cta{text-decoration:underline}

/* ============ Restaurant Single ============ */
.wwb-restaurant{background:var(--c-bg)}
.wwb-rest-hero{position:relative;height:60vh;min-height:420px;overflow:hidden}
.wwb-rest-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.55)}
.wwb-rest-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,18,.3) 0%,rgba(10,22,18,.85) 100%)}
.wwb-rest-hero__inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:50px}
.wwb-rest-hero__title{font-size:clamp(32px,5vw,56px);margin:8px 0 16px;font-weight:700;line-height:1.2;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.6)}
.wwb-rest-hero__meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--c-sub);font-size:13px}
.wwb-rest-hero__meta span{padding:6px 14px;background:rgba(0,0,0,.4);border:1px solid var(--c-line);border-radius:99px}
.wwb-rest-hero__meta a{color:var(--c-gold);text-decoration:none}

.wwb-rest-body{display:grid;grid-template-columns:1fr 360px;gap:60px;padding:60px 24px}
.wwb-rest-main{min-width:0}
.wwb-rest-h2{font-size:24px;margin:48px 0 20px;padding-bottom:8px;border-bottom:1px solid var(--c-line);color:var(--c-text)}

.wwb-rest-gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.wwb-rest-gallery__item{display:block;aspect-ratio:1;overflow:hidden;border-radius:4px;background:#222}
.wwb-rest-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.wwb-rest-gallery__item:hover img{transform:scale(1.06)}

.wwb-rest-map__frame{border:1px solid var(--c-line);border-radius:6px;overflow:hidden}
.wwb-rest-map__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

/* Sticky info card */
.wwb-rest-side{position:relative}
.wwb-rest-card{position:sticky;top:90px;background:var(--c-bg2);border:1px solid var(--c-line);border-radius:6px;padding:28px}
.wwb-rest-card__title{font-size:22px;margin:0 0 4px;font-weight:700;line-height:1.3}
.wwb-rest-card__sub{color:var(--c-gold);font-size:12px;letter-spacing:1px;margin:0 0 20px}
.wwb-rest-card__list{display:grid;grid-template-columns:1fr;gap:0;margin:0 0 24px}
.wwb-rest-card__list dt{color:var(--c-sub);font-size:11px;letter-spacing:1px;margin-top:14px;font-weight:700}
.wwb-rest-card__list dt:first-child{margin-top:0}
.wwb-rest-card__list dd{color:var(--c-text);font-size:14px;margin:4px 0 0;line-height:1.5;word-break:break-word}
.wwb-rest-card__list dd a{color:var(--c-gold);text-decoration:none}
.wwb-rest-card__list dd a:hover{text-decoration:underline}
.wwb-rest-card__actions{display:grid;gap:8px}
.wwb-rest-card__actions .wwb-btn{padding:12px 16px;font-size:13px}

.wwb-rest-card-mini__addr{font-size:11px;color:var(--c-sub);margin-top:8px}

@media (max-width:900px){
  .wwb-rest-body{grid-template-columns:1fr;gap:40px;padding:40px 24px}
  .wwb-rest-card{position:static}
  .wwb-rest-hero{height:auto;min-height:360px}
  .wwb-rest-gallery__grid{grid-template-columns:repeat(2,1fr)}
}

/* ============ Restaurant All-Map ============ */
.wwb-rest-allmap{border-radius:6px;overflow:hidden}
.gm-style .gm-style-iw-c{border-radius:6px!important}
.gm-style .gm-style-iw-d{overflow:auto!important}

/* ============ Globe floating labels ============ */
.wwb-globe{position:relative}
.wwb-globe-label{
  position:absolute;top:10%;right:5%;
  background:rgba(212,168,71,0.95);color:#1a1a1a;
  padding:10px 20px;border-radius:28px;
  font-size:18px;font-weight:700;letter-spacing:0.5px;
  box-shadow:0 8px 24px rgba(0,0,0,0.35);
  opacity:0;transform:translateY(-8px) scale(0.9);
  transition:none;pointer-events:none;
  white-space:nowrap;
  z-index:3;
  font-family:var(--f-jp)
}
.wwb-globe-label.is-show{
  animation:wwb-label-in 3.5s ease-out forwards
}
.wwb-globe-label-flag{
  position:absolute;top:calc(10% - 32px);right:5%;
  font-size:24px;opacity:0;
  transition:none;pointer-events:none;z-index:3
}
.wwb-globe-label-flag.is-show{
  animation:wwb-flag-in 3.5s ease-out forwards
}
@keyframes wwb-label-in{
  0%{opacity:0;transform:translateY(-8px) scale(0.9)}
  10%{opacity:1;transform:translateY(0) scale(1)}
  80%{opacity:1;transform:translateY(0) scale(1)}
  100%{opacity:0;transform:translateY(8px) scale(0.95)}
}
@keyframes wwb-flag-in{
  0%{opacity:0}
  10%{opacity:1}
  80%{opacity:1}
  100%{opacity:0}
}

@media (max-width:900px){
  .wwb-globe-label{font-size:15px;padding:8px 16px;top:4%;right:4%}
  .wwb-globe-label-flag{top:calc(4% - 26px);font-size:20px;right:4%}
}
