/* Rakugou mobile site stylesheet - integrated from static template */
:root{
  --blue:#082b57;
  --blue2:#061f41;
  --red:#d93636;
  --gold:#c49a4a;
  --ink:#12243a;
  --muted:#6a7788;
  --line:#e9edf3;
  --bg:#f6f8fb;
  --card:#ffffff;
  --radius:18px;
  --shadow:0 10px 28px rgba(8,43,87,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;color:var(--ink);background:#fff;line-height:1.7}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.page{min-height:100vh;padding-bottom:78px;background:#fff}
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.topbar-inner{height:62px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand{display:flex;align-items:center;gap:9px;min-width:0}
.brand img{width:40px;height:40px;border-radius:12px;object-fit:cover}
.brand strong{display:block;color:var(--blue);font-size:17px;letter-spacing:.08em;line-height:1}
.brand small{display:block;color:var(--blue);font-size:11px;margin-top:4px;white-space:nowrap}
.header-actions{display:flex;align-items:center;gap:8px}
.icon-btn,.menu-btn{width:40px;height:40px;border-radius:13px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;font-weight:800;color:var(--blue)}
.menu-btn{background:var(--blue);border-color:var(--blue);gap:4px;padding:0}
.menu-btn i{display:block;width:17px;height:2px;background:#fff;border-radius:3px}
.drawer{display:none;padding:8px 16px 18px;background:#fff;border-top:1px solid var(--line)}
.drawer.open{display:grid}
.drawer a{padding:13px 2px;border-bottom:1px solid #f0f2f5;color:var(--blue);font-weight:800}
.drawer .drawer-tools{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.mini-btn{height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px}
.mini-btn.red{background:var(--red);color:#fff}
.mini-btn.outline{border:1px solid var(--blue);color:var(--blue)}
.hero{position:relative;padding:28px 16px 24px;overflow:hidden;background:linear-gradient(135deg,#fff 0%,#f8fbff 55%,#fff7f4 100%)}
.hero:before{content:"";position:absolute;right:-70px;top:-65px;width:230px;height:230px;border-radius:50%;background:rgba(217,54,54,.12)}
.hero h1{position:relative;margin:12px 0 12px;color:var(--blue);font-size:32px;line-height:1.22;letter-spacing:.03em}
.eyebrow{position:relative;margin:0;color:var(--gold);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.lead{position:relative;margin:0 0 20px;color:#33465c;font-size:14px}
.search-box{position:relative;display:flex;gap:8px;padding:8px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow)}
.search-box input{flex:1;border:0;outline:0;font-size:14px;padding:0 6px;color:var(--ink);min-width:0;background:transparent}
.search-box button{width:46px;border:0;border-radius:12px;background:var(--blue);color:#fff;font-weight:900}
.quick{padding:14px 16px;background:#fff;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;border-bottom:1px solid var(--line)}
.quick a{height:74px;border:1px solid var(--line);border-radius:16px;background:#fff;display:grid;place-items:center;text-align:center;color:var(--blue);font-size:12px;font-weight:800;box-shadow:0 6px 14px rgba(8,43,87,.04)}
.quick span{display:block;font-size:20px;line-height:1}
.section{padding:30px 16px}
.section.alt{background:var(--bg)}
.sec-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:15px;gap:10px}
h2{margin:0;color:var(--blue);font-size:22px;line-height:1.3;letter-spacing:.03em}
.sec-link{font-size:13px;color:var(--red);font-weight:900;white-space:nowrap}
.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.category-card{min-height:118px;padding:16px;border-radius:var(--radius);background:linear-gradient(180deg,#fff,#faf6f2);border:1px solid #eee8df;box-shadow:0 8px 18px rgba(8,43,87,.05)}
.category-card span{font-size:28px}
.category-card strong{display:block;margin-top:8px;color:var(--blue);font-size:15px}
.category-card small{display:block;color:var(--muted);font-size:12px;margin-top:3px}
.company-card{padding:18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.company-card p{margin:0 0 14px;color:#44556a;font-size:14px}
.info-row{display:flex;gap:10px;padding:12px 0;border-top:1px solid var(--line)}
.info-row b{width:86px;flex:0 0 86px;color:var(--blue);font-size:13px}
.info-row span{font-size:13px;color:#33465c}
.business-list{display:grid;gap:12px}
.business-card{display:flex;gap:14px;align-items:flex-start;padding:17px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 18px rgba(8,43,87,.05)}
.business-card .ico{width:42px;height:42px;border-radius:14px;background:#f4f7fb;display:grid;place-items:center;font-size:22px}
.business-card h3{margin:0 0 4px;color:var(--blue);font-size:16px}
.business-card p{margin:0;color:var(--muted);font-size:13px}
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.product-card{border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 8px 18px rgba(8,43,87,.05)}
.product-img{height:120px;display:grid;place-items:center;background:linear-gradient(135deg,#fdf5f5,#f5f9ff);font-size:42px}
.product-body{padding:12px}
.product-body small{display:block;color:var(--gold);font-weight:900;font-size:11px}
.product-body strong{display:block;color:var(--blue);font-size:14px;margin-top:4px}
.product-body .price{display:flex;align-items:center;justify-content:space-between;margin-top:10px;color:var(--red);font-weight:900}
.cart-add{width:32px;height:32px;border-radius:10px;border:0;background:var(--blue);color:#fff}
.news-list{display:grid;gap:12px}
.news-card{padding:16px;border:1px solid var(--line);border-radius:17px;background:#fff}
.news-card time{display:block;color:var(--gold);font-size:12px;font-weight:900}
.news-card strong{display:block;color:var(--blue);margin:5px 0;font-size:15px}
.news-card p{margin:0;color:var(--muted);font-size:13px}
.form-card{padding:18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.field{margin-bottom:13px}
.field label{display:block;font-size:12px;font-weight:900;color:var(--blue);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;height:48px;border:1px solid #dce3ec;border-radius:13px;padding:0 12px;font-size:14px;outline:0;background:#fff}
.field textarea{height:110px;padding-top:10px}
.btn{width:100%;height:50px;border:0;border-radius:14px;background:var(--blue);color:#fff;font-weight:900;font-size:15px;display:flex;align-items:center;justify-content:center}
.btn.red{background:var(--red)}
.btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--blue)}
.btn + .btn{margin-top:10px}
.auth-switch{text-align:center;color:var(--muted);font-size:13px;margin-top:14px}
.auth-switch a{color:var(--red);font-weight:900}
.cart-item{display:flex;gap:12px;padding:14px;border-radius:18px;background:#fff;border:1px solid var(--line);margin-bottom:12px}
.cart-thumb{width:72px;height:72px;border-radius:14px;background:linear-gradient(135deg,#fff2f2,#f5f9ff);display:grid;place-items:center;font-size:30px;flex:0 0 72px;overflow:hidden}
.cart-thumb img{width:100%;height:100%;object-fit:cover}
.cart-info{flex:1;min-width:0}
.cart-info strong{display:block;color:var(--blue);font-size:14px}
.cart-info small{color:var(--muted)}
.qty{display:flex;align-items:center;gap:8px;margin-top:8px}
.qty button{width:28px;height:28px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--blue)}
.summary{position:sticky;bottom:76px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:var(--shadow)}
.summary-row{display:flex;justify-content:space-between;margin-bottom:12px}
.footer{padding:32px 16px 92px;background:var(--blue2);color:#dbe6f3}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-brand img{width:42px;height:42px;background:#fff;border-radius:12px;object-fit:cover}
.footer-brand strong{color:#fff;letter-spacing:.08em}
.footer nav{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:18px 0}
.footer a{color:#fff;font-size:13px}
.footer small{color:#9eb0c8}
.tabbar{position:fixed;left:0;right:0;bottom:0;height:66px;background:#fff;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);z-index:60;box-shadow:0 -8px 22px rgba(8,43,87,.08)}
.tabbar a{display:grid;place-items:center;text-align:center;color:#718096;font-size:11px;font-weight:800;padding-top:6px;position:relative}
.tabbar a.active{color:var(--blue)}
.tabbar span{display:block;font-size:20px;line-height:1}
.badge{position:absolute;right:18px;top:8px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--red);color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center}
.notice{padding:12px 16px;background:#fff7e8;color:#79540b;font-size:13px;border-top:1px solid #f4dfb7;border-bottom:1px solid #f4dfb7}
.breadcrumb{padding:14px 16px;background:#f7f9fc;color:var(--muted);font-size:12px}
.page-title{padding:26px 16px;background:linear-gradient(135deg,#f8fbff,#fff7f4)}
.page-title h1{margin:0;color:var(--blue);font-size:28px}
.page-title p{margin:8px 0 0;color:var(--muted);font-size:14px}
.filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px}
.filter-row a{padding:9px 12px;border:1px solid var(--line);border-radius:999px;background:#fff;white-space:nowrap;color:var(--blue);font-size:13px;font-weight:800}
.filter-row a.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.product-hero{padding:24px 16px;background:linear-gradient(135deg,#fff2f2,#f6f9ff);display:grid;place-items:center;font-size:86px}
.product-detail{padding:22px 16px}
.product-detail h1{margin:0;color:var(--blue);font-size:24px}
.product-detail .price-big{color:var(--red);font-size:24px;font-weight:900;margin:10px 0}
.detail-box{padding:15px;border-radius:16px;background:#f7f9fc;color:#536377;font-size:14px;margin-top:16px}
.actions-sticky{position:fixed;left:0;right:0;bottom:66px;padding:10px 16px;background:#fff;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1.3fr;gap:10px;z-index:55}
.rakugou-mobile-shell{min-height:100vh;padding-bottom:78px;background:#fff}
.rakugou-mobile-main{padding-bottom:24px}
.mobile-section{padding:24px 16px}
.mobile-auth-wrap{padding:18px 16px 32px}
.mobile-auth-card{padding:18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.mobile-auth-card .panel-heading,.mobile-auth-card .panel-section>.panel-heading{margin-bottom:14px}
.mobile-auth-card .panel-heading .title,.mobile-auth-card .panel-section>.panel-heading .title{font-size:20px;color:var(--blue);font-weight:800}
.mobile-auth-card .form-group{margin-bottom:14px}
.mobile-auth-card .form-control{width:100%;height:48px;border:1px solid #dce3ec;border-radius:13px;padding:0 12px;font-size:14px;outline:0;background:#fff}
.mobile-auth-card .control-label{display:block;font-size:12px;font-weight:900;color:var(--blue);margin-bottom:6px}
.mobile-auth-card .btn.primary,.mobile-auth-card .btn.block,.mobile-auth-card .btn.btn-primary{width:100%;height:50px;border-radius:14px;background:var(--blue);color:#fff;font-weight:900;border:0;display:flex;align-items:center;justify-content:center}
.mobile-auth-card .btn-link{display:inline-block;color:var(--red);font-weight:900;padding:0;background:none;border:0}
.mobile-auth-links{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:10px;font-size:13px}
.mobile-page-head{padding:24px 16px 16px;background:linear-gradient(135deg,#f8fbff,#fff7f4)}
.mobile-page-head h1{margin:6px 0 0;color:var(--blue);font-size:28px;line-height:1.25}
.mobile-page-head p{margin:8px 0 0;color:var(--muted);font-size:14px}
.mobile-card{padding:18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.mobile-product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.mobile-product-card{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;box-shadow:0 6px 16px rgba(8,43,87,.05);display:flex;flex-direction:column;height:100%}
.mobile-product-card .thumb{height:auto;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fdf5f5,#f5f9ff);overflow:hidden;padding:8px}
.mobile-product-card .thumb img{width:100%;height:100%;object-fit:contain}
.mobile-product-card .thumb span{padding:12px;text-align:center;color:var(--blue);font-weight:800;font-size:13px}
.mobile-product-card .body{padding:10px;display:flex;flex-direction:column;flex:1}
.mobile-product-card .meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:5px}
.mobile-product-card .tag{display:inline-flex;align-items:center;min-height:20px;padding:0 7px;border-radius:999px;background:#eef3fb;color:var(--blue);font-size:10px;font-weight:800}
.mobile-product-card h3{margin:0;color:var(--blue);font-size:13px;line-height:1.35;min-height:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.mobile-product-card .desc{display:none}
.mobile-product-card .price{margin-top:7px;color:var(--red);font-size:16px;font-weight:900}
.mobile-product-card .link{display:inline-flex;align-items:center;justify-content:center;width:100%;height:38px;margin-top:auto;border-radius:10px;background:var(--blue);color:#fff;font-weight:900;font-size:12px}
.mobile-chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.mobile-chip{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 14px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--blue);font-size:13px;font-weight:800;white-space:nowrap}
.mobile-chip.active{background:var(--blue);border-color:var(--blue);color:#fff}
.mobile-cart-list{display:grid;gap:12px}
.mobile-cart-item{display:flex;gap:12px;padding:14px;border-radius:18px;background:#fff;border:1px solid var(--line)}
.mobile-cart-thumb{width:78px;height:78px;border-radius:14px;background:linear-gradient(135deg,#fff2f2,#f5f9ff);display:grid;place-items:center;overflow:hidden;flex:0 0 78px}
.mobile-cart-thumb img{width:100%;height:100%;object-fit:cover}
.mobile-cart-thumb span{padding:8px;text-align:center;color:var(--blue);font-size:12px;font-weight:800;line-height:1.4}
.mobile-cart-body{flex:1;min-width:0}
.mobile-cart-title{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.mobile-cart-title strong{display:block;color:var(--blue);font-size:14px;line-height:1.5}
.mobile-cart-delete{color:var(--red);font-size:12px;font-weight:900;white-space:nowrap}
.mobile-cart-meta{margin-top:6px;display:grid;gap:4px;font-size:12px;color:var(--muted)}
.mobile-qty{display:flex;align-items:center;gap:8px;margin-top:10px}
.mobile-qty button{width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--blue);font-size:18px;line-height:1}
.mobile-qty input{width:54px;height:34px;border:1px solid #dce3ec;border-radius:10px;text-align:center;font-size:14px}
.mobile-summary{position:sticky;bottom:76px;padding:14px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.mobile-summary-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;color:var(--ink);font-size:14px}
.mobile-summary-row strong{color:var(--red);font-size:18px}
.mobile-empty{padding:18px;border-radius:20px;background:#fff;border:1px dashed #d6dfeb;text-align:center;color:var(--muted)}
.mobile-empty .actions{display:grid;gap:10px;margin-top:14px}
.mobile-company-list,.mobile-news-list,.mobile-contact-list{display:grid;gap:12px}
.mobile-info-card,.mobile-news-card,.mobile-contact-card{padding:16px;border-radius:18px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 18px rgba(8,43,87,.05)}
.mobile-info-card small,.mobile-contact-card small,.mobile-news-card time{display:block;color:var(--gold);font-size:12px;font-weight:900}
.mobile-info-card strong,.mobile-contact-card strong,.mobile-news-card strong{display:block;margin-top:6px;color:var(--blue);font-size:15px;line-height:1.5}
.mobile-news-card p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.7}
.mobile-product-detail-hero{padding:20px 16px;background:linear-gradient(135deg,#fff2f2,#f6f9ff);display:grid;place-items:center}
.mobile-product-detail-hero .hero-image{width:100%;aspect-ratio:1/1;border-radius:22px;overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.mobile-product-detail-hero img{width:100%;height:100%;object-fit:cover}
.mobile-product-detail-hero .placeholder{width:100%;height:100%;display:grid;place-items:center;font-size:72px;color:var(--blue)}
.mobile-product-detail{padding:20px 16px 120px}
.mobile-product-detail .price{margin-top:8px;color:var(--red);font-size:26px;font-weight:900}
.mobile-product-detail .summary{margin-top:14px;padding:14px 16px;border-radius:16px;background:#f7f9fc;color:#536377;font-size:14px;line-height:1.8;position:static;bottom:auto;box-shadow:none}
.mobile-meta-list{display:grid;gap:10px;margin-top:16px}
.mobile-meta-item{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--line);font-size:13px}
.mobile-meta-item dt{width:88px;flex:0 0 88px;color:var(--blue);font-weight:900}
.mobile-meta-item dd{margin:0;color:#33465c;min-width:0}
.mobile-action-bar{position:fixed;left:0;right:0;bottom:66px;padding:10px 16px;background:#fff;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1.25fr;gap:10px;z-index:55}
.mobile-action-bar .btn{height:48px;margin:0}
.mobile-action-bar .btn.ghost{background:#fff;border:1px solid var(--blue);color:var(--blue)}
.mobile-order-note{display:grid;gap:10px;margin-top:18px}
.mobile-order-note .note{padding:14px 16px;border-radius:16px;background:#fff;border:1px solid var(--line);font-size:13px;color:#44556a}
.mobile-order-note .note strong{display:block;margin-bottom:6px;color:var(--blue)}
.mobile-rich{padding:18px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 18px rgba(8,43,87,.05)}
.mobile-rich img{max-width:100%;height:auto}
.mobile-plain-actions{display:grid;gap:10px;margin-top:16px}
.mobile-plain-actions .btn-link-block{display:flex;align-items:center;justify-content:center;height:48px;border-radius:14px;background:var(--blue);color:#fff;font-weight:900}
.mobile-plain-actions .btn-link-light{display:flex;align-items:center;justify-content:center;height:48px;border-radius:14px;border:1px solid var(--blue);color:var(--blue);font-weight:900;background:#fff}
.mobile-deny-card{margin:18px 16px;padding:22px 18px;border-radius:22px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);text-align:center}
.mobile-deny-card .icon{font-size:48px;color:var(--red);display:block;margin-bottom:12px}
.mobile-deny-card h1{margin:0;color:var(--blue);font-size:22px}
.mobile-deny-card p{margin:12px 0 0;color:var(--muted);font-size:14px;line-height:1.7}
.mobile-deny-actions{display:grid;gap:10px;margin-top:18px}
.rakugou-mobile-hide{display:none!important}
@media(min-width:640px){
  body{max-width:480px;margin:0 auto;background:#eef2f6}
  .topbar,.tabbar,.actions-sticky,.mobile-action-bar{max-width:480px;margin:0 auto}
}
/* Rakugou mobile homepage hero overrides */
.hero{position:relative;padding:12px 16px 18px!important;background:#f7f7f5!important;overflow:hidden}
.hero:before{display:none!important}
.rakugou-home-mobile .hero-visual{position:relative;min-height:272px;height:272px;border-radius:24px;overflow:hidden;box-shadow:0 12px 28px rgba(8,43,87,.10);background:#fff}
.rakugou-home-mobile .hero-visual img{position:absolute;inset:-12% -14% -8% -8%;width:122%;height:118%;max-width:none;display:block;object-fit:cover;object-position:42% 28%;filter:blur(1.2px) saturate(.94) brightness(.92);transform:scale(1.08)}
.rakugou-home-mobile .hero-visual::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.56) 0%,rgba(255,255,255,.28) 34%,rgba(255,255,255,.08) 70%)}
.rakugou-home-mobile .hero-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,22,42,.03) 0%,rgba(8,22,42,.10) 30%,rgba(8,22,42,.44) 100%)}
.rakugou-home-mobile .hero-copy{position:absolute;left:18px;right:18px;bottom:16px;z-index:2;color:#fff}
.rakugou-home-mobile .hero-copy .eyebrow{color:#f3d39a;text-shadow:0 2px 10px rgba(0,0,0,.22)}
.rakugou-home-mobile .hero-copy h1{margin:8px 0 8px;color:#fff;font-size:28px;line-height:1.22;letter-spacing:.03em;text-shadow:0 4px 16px rgba(0,0,0,.24)}
.rakugou-home-mobile .hero-copy .lead{margin:0;max-width:88%;color:rgba(255,255,255,.96);font-size:13px;line-height:1.78;text-shadow:0 2px 10px rgba(0,0,0,.22)}
.tabbar{grid-template-columns:repeat(4,1fr)!important}

/* iPhone safe-area topbar fix */
.topbar{padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top)}
.topbar-inner{min-height:calc(62px + constant(safe-area-inset-top));min-height:calc(62px + env(safe-area-inset-top));height:auto}
.drawer{padding-top:max(8px, env(safe-area-inset-top))}

/* remove unexpected top gap on iPhone/mobile homepage */
html.m-index-index body{padding-top:0!important;margin-top:0!important}
html.m-index-index .topbar{margin-top:0!important;top:0!important}
html.m-index-index .page.rakugou-mobile-shell{padding-top:0!important}

/* global mobile page top-gap fix */
html[class*="m-"] body{padding-top:0!important;margin-top:0!important}
html[class*="m-"] .topbar{top:0!important;margin-top:0!important;padding-top:0!important}
html[class*="m-"] .topbar-inner{min-height:62px!important;height:62px!important}
html[class*="m-"] .page,
html[class*="m-"] .rakugou-mobile-shell,
html[class*="m-"] .rakugou-subpage-wrap,
html[class*="m-"] .rakugou-account-wrap{padding-top:0!important;margin-top:0!important}

/* force mobile menu button visible on all mobile pages */
html[class*="m-"] .topbar .menu-btn{display:grid!important}

/* ensure topbar menu button stays visible on mobile pages */
html[class*="m-"] .topbar .header-actions .menu-btn{
  display:grid!important;
  place-items:center!important;
  width:40px!important;
  height:40px!important;
  min-width:40px!important;
  min-height:40px!important;
  visibility:visible!important;
  opacity:1!important;
  flex:0 0 40px!important;
}
