/* ============================================================
   å£ç´™å??ã‚µãƒ–ã?ãƒ¼ã‚¸å…±é€šã‚¹ã‚¿ã‚¤ãƒ«  kabe_sub.css
   æ˜­å’Œãƒ¬ãƒˆãƒ­ / ãƒ¢ãƒã‚¤ãƒ«ãƒ•ã‚¡ãƒ¼ã‚¹ãƒ?   ============================================================ */

/* ---------- ãƒªã‚»ãƒ?ƒˆãƒ»åŸºæœ¬ ---------- */
* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  background: #f7f1e4;
  color: #2b2b2b;
  line-height: 1.7;
  -webkit-text-size-adjust: 100%;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ---------- ãƒšã?ã‚¸ãƒ©ãƒ?ƒ‘ãƒ¼ ---------- */
.page {
  max-width: 768px;
  margin: 0 auto;
  background: #fffdf7;
  min-height: 100vh;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}

/* ---------- ãƒ˜ãƒƒãƒ?ãƒ¼ä½™ç™½?ˆå?é€šã?ãƒ?ƒ€ãƒ¼æŒ¿å…¥ä½ç½®ãƒ»è‰²ãªã—ï¼?---------- */
.sub-header-space {
  height: 57px;
}

/* ============================================================
   æ˜­å’Œçœ‹æ¿ ãƒšã?ã‚¸ã‚¿ã‚¤ãƒˆãƒ«ã‚¨ãƒªã‚¢
   ============================================================ */
.sub-page-header {
  position: relative;
  overflow: hidden;
  background-color: #8f1a12;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cg opacity='0.13'%3E%3Ccircle cx='30' cy='18' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='48' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='33' r='9' fill='%23ff6b1a'/%3E%3Ccircle cx='30' cy='33' r='4' fill='%23ffe066'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #8f1a12 0%, #b32025 50%, #7a1010 100%);
  padding: 16px 16px 18px;
  border-bottom: 3px solid #e3b93c;
}

/* çœ‹æ¿ãƒ–ãƒ­ãƒ?‚¯ */
.sub-signboard {
  text-align: center;
}

.sub-signboard-inner {
  display: block;
  width: 100%;
  background: linear-gradient(180deg, #2a1208 0%, #1a0804 100%);
  border: 3px solid #e8c96a;
  border-radius: 5px;
  padding: 13px 20px 13px;
  position: relative;
  box-sizing: border-box;
  box-shadow:
    0 0 0 1px rgba(232,201,106,0.25),
    inset 0 1px 0 rgba(255,255,255,0.08),
    3px 3px 0 rgba(0,0,0,0.3),
    0 6px 18px rgba(0,0,0,0.4);
}

/* å››éš…ãƒ“ã‚¹ */
.sub-signboard-inner::before,
.sub-signboard-inner::after {
  content: "\25C6";
  position: absolute;
  font-size: 8px;
  color: #e8c96a;
  top: 6px;
  opacity: 0.7;
}
.sub-signboard-inner::before { left: 8px; }
.sub-signboard-inner::after  { right: 8px; }

/* ã‚µãƒ¼ãƒ“ã‚¹ãƒ©ãƒ™ãƒ« */
.sub-signboard-label {
  display: block;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.4em;
  color: #e8c96a;
  text-transform: uppercase;
  margin-bottom: 7px;
  opacity: 0.8;
}

/* h1 ã‚¿ã‚¤ãƒˆãƒ«?šçœ‹æ¿ã®ä¸­ã«å…¥ã‚?*/
.sub-signboard-inner h1 {
  margin: 0;
  font-size: 17px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.12em;
  line-height: 1.45;
  text-align: center;
  text-shadow:
    0 0 10px rgba(232,201,106,0.5),
    0 2px 6px rgba(0,0,0,0.8);
}

/* ============================================================
   ãƒ¡ã‚¤ãƒ³ã‚³ãƒ³ãƒ?ƒ³ãƒ??˜åŸŸ
   ============================================================ */
.sub-main {
  padding: 20px 16px 40px;
  background: #fffdf7;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23fffdf7'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23f0e8d4' opacity='0.25'/%3E%3C/svg%3E");
  font-size: 14px;
  color: #3a2a18;
}

/* ---------- h2è¦‹å?ã?---------- */
.sub-main h2 {
  margin: 20px 0 16px;
  font-size: 14px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.06em;
  line-height: 1.5;
  padding: 10px 14px;
  background: linear-gradient(135deg, #f5ede0 0%, #eddcc4 100%);
  border-left: 4px solid #b32025;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.15);
}

/* ---------- ul.link?ˆãŠå•ã„åˆã‚ã›ã?ãƒ¼ã‚¸ç”¨??---------- */
ul.link {
  list-style: none;
  margin: 16px 0;
  padding: 0;
}

ul.link li {
  margin: 0 0 12px;
  padding: 0;
  font-size: 14px;
  line-height: 1.7;
}

ul.link li.title {
  padding: 12px 14px;
  background: #fff8f3;
  border: 2px solid #b32025;
  border-radius: 3px;
  font-weight: 700;
  color: #3a2a18;
  margin-bottom: 16px;
  box-shadow: 2px 2px 0 rgba(179,32,37,0.15);
}

ul.link li.tellch {
  padding: 14px 16px;
  background: #fffdf5;
  border: 2px solid #c8a030;
  border-radius: 3px;
  margin-bottom: 16px;
}

ul.link li.tellch input[type="checkbox"] {
  accent-color: #b32025;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  vertical-align: middle;
  cursor: pointer;
}

ul.link li.tellch label {
  font-size: 14px;
  font-weight: 600;
  color: #3a2a18;
  cursor: pointer;
  vertical-align: middle;
}

ul.link li.icon_arrow {
  text-align: center;
  margin-top: 20px;
}

ul.link li.icon_arrow a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  background: linear-gradient(135deg, #27ae60 0%, #1e8449 100%);
  color: #fff !important;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-decoration: none !important;
  border: 2px solid #1e8449;
  border-radius: 5px;
  box-shadow: 3px 3px 0 rgba(30,132,73,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
}

ul.link li.icon_arrow a img.icon {
  width: 24px;
  height: 24px;
  display: inline-block;
}

ul.link li.icon_arrow a:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(30,132,73,0.3);
}

/* ---------- ul.radius?ˆç‰¹å®šå•†å–å¼•æ³•ãªã©é•·æ–??ãƒ¼ã‚¸ç”¨??---------- */
ul.radius {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
}

ul.radius li {
  background: #f5ede0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  border: 2px solid #8f2b1d;
  border-radius: 4px;
  padding: 22px 18px 24px;
  box-shadow:
    3px 3px 0 rgba(143,43,29,0.18),
    0 4px 16px rgba(0,0,0,0.06);
  position: relative;
  font-size: 14px;
  line-height: 1.85;
  color: #3a2a18;
}

ul.radius li::before {
  content: "\25C6";
  position: absolute;
  top: 6px;
  left: 8px;
  font-size: 7px;
  color: #8f2b1d;
  opacity: 0.45;
}

ul.radius li::after {
  content: "\25C6";
  position: absolute;
  top: 6px;
  right: 8px;
  font-size: 7px;
  color: #8f2b1d;
  opacity: 0.45;
}

/* ä¸­å¤®å¯?› */
ul.radius li.aC {
  text-align: center;
}

ul.radius li.aC img {
  margin: 8px auto;
  display: inline-block;
}

/* boxå†??pè¦ç´? */
ul.radius li p {
  margin: 6px 0;
  padding-left: 12px;
  font-size: 12px;
  line-height: 1.8;
text-align: left;
}

/* ---------- åˆ©ç”¨è¦ç´?°‚ç”¨ã‚¹ã‚¿ã‚¤ãƒ« ---------- */
.kiyaku-section {
  margin: 20px 0;
  padding: 16px 0;
  border-bottom: 1px dashed rgba(143,43,29,0.2);
}

.kiyaku-section:last-child {
  border-bottom: none;
}

.kiyaku-title {
  display: block;
  margin: 0 0 12px;
  padding: 10px 14px;
  font-size: 16px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-left: 5px solid #e8c96a;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  line-height: 1.5;
}

.kiyaku-item {
  margin: 8px 0;
  padding-left: 8px;
  line-height: 1.9;
}

.kiyaku-subitem {
  margin: 4px 0;
  padding-left: 24px;
  line-height: 1.8;
  color: #4a3a28;
  font-size: 13px;
}

.kiyaku-important {
  display: inline-block;
  padding: 0 4px;
  background: linear-gradient(transparent 70%, #ffe066 70%);
  font-weight: 700;
}

/* ---------- ãƒ¡ãƒ³ãƒ?ƒŠãƒ³ã‚¹ãƒ¡ãƒ?‚»ãƒ¼ã‚¸ ---------- */
.maintenance-message {
  text-align: center;
  padding: 32px 20px;
  margin: 24px 0;
  background: #f5ede0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  border: 2px solid #8f2b1d;
  border-radius: 4px;
  box-shadow:
    3px 3px 0 rgba(143,43,29,0.2),
    0 6px 18px rgba(0,0,0,0.08);
  position: relative;
  font-size: 15px;
  font-weight: 600;
  color: #3a2a18;
  line-height: 1.9;
}

.maintenance-message::before {
  content: "\25C6";
  position: absolute;
  top: 7px;
  left: 9px;
  font-size: 8px;
  color: #8f2b1d;
  opacity: 0.5;
}

.maintenance-message::after {
  content: "\25C6";
  position: absolute;
  top: 7px;
  right: 9px;
  font-size: 8px;
  color: #8f2b1d;
  opacity: 0.5;
}

/* ---------- å¯¾å¿œæ©Ÿç¨®ãƒšã?ã‚¸ ---------- */
.kishu-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0 0 24px;
}

.kishu-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 0;
  box-shadow: 4px 4px 0 rgba(42,26,14,0.3);
  position: relative;
}

/* OSã‚¢ã‚¤ã‚³ãƒ³ãƒœãƒƒã‚¯ã‚¹ */
.kishu-icon {
  flex: 0 0 auto;
  padding: 8px 14px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-align: center;
  border: 2px solid #e8c96a;
  box-shadow: 2px 2px 0 rgba(0,0,0,0.2);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.4);
  min-width: 90px;
}

.kishu-details {
  flex: 1;
  display: flex;
  align-items: center;
}

.kishu-ver {
  font-size: 15px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.06em;
  text-shadow: 1px 1px 0 rgba(255,255,255,0.5);
}

.kishu-note {
  margin: 16px 0 0;
  padding: 14px 18px;
  background: linear-gradient(transparent 70%, #ffcccc 70%);
  border: 3px solid #b32025;
  border-radius: 0;
  font-size: 14px;
  font-weight: 900;
  color: #7a1010;
  text-align: center;
  box-shadow: 3px 3px 0 rgba(179,32,37,0.2);
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.test-info {
  margin: 20px 0 0;
  padding: 14px 16px;
  background: #fff8e1;
  border: 2px solid #c8a030;
  border-radius: 3px;
  font-size: 13px;
  font-weight: 600;
  color: #5a4a20;
  line-height: 1.8;
  box-shadow: 2px 2px 0 rgba(200,160,48,0.2);
}

/* ---------- ã”åˆ©ç”¨ã‚¬ã‚¤ãƒ‰ã?ãƒ¼ã‚¸ ---------- */
.guide-section {
  margin: 0 0 28px;
  padding: 0 0 24px;
  border-bottom: 1px dashed rgba(143,43,29,0.25);
}

.guide-section:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.guide-title {
  margin: 0 0 14px;
  padding: 10px 14px 10px 44px;
  font-size: 16px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #fffdf5 0%, #f5ede0 100%);
  border-left: 5px solid #b32025;
  border-top: 2px solid #2a1a0e;
  border-bottom: 2px solid #2a1a0e;
  box-shadow: 2px 2px 0 rgba(42,26,14,0.15);
  text-shadow: 1px 1px 0 rgba(255,255,255,0.4);
  position: relative;
}

.guide-title::before {
  content: "\25A0";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  color: #b32025;
}

.guide-section > p {
  margin: 0 0 12px;
  padding-left: 8px;
  font-size: 14px;
  line-height: 1.85;
  color: #3a2a18;
}

.guide-section > p:last-child {
  margin-bottom: 0;
}

.guide-list {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
}

.guide-list li {
  margin: 0 0 10px;
  padding: 10px 12px 10px 28px;
  background: rgba(255,255,255,0.5);
  border-left: 3px solid #c8a030;
  font-size: 14px;
  line-height: 1.8;
  color: #3a2a18;
  position: relative;
}

.guide-list li::before {
  content: "\25C6";
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 7px;
  color: #c8a030;
}

.guide-important {
  display: inline;
  background: linear-gradient(transparent 70%, #ffeb3b 70%);
  padding: 0 4px;
  font-weight: 700;
  color: #b32025;
}

.guide-caution {
  margin: 12px 0 0;
  padding: 12px 16px;
  background: #fff8f3;
  border: 2px solid #b32025;
  border-radius: 3px;
  font-size: 14px;
  font-weight: 700;
  color: #7a1010;
  text-align: center;
  box-shadow: 2px 2px 0 rgba(179,32,37,0.15);
  line-height: 1.7;
}

/* ---------- é€?ä¼šå®Œäº??ãƒ¼ã‚¸ ---------- */
.thanks-message {
  margin: 0 0 24px;
  padding: 18px;
  background: rgba(255,255,255,0.6);
  border: 3px solid #b32025;
  border-radius: 3px;
  text-align: center;
  box-shadow: 2px 2px 0 rgba(179,32,37,0.15);
}

.thanks-title {
  margin: 0;
  font-size: 16px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.retire-section {
  margin: 0 0 28px;
  padding: 0 0 24px;
  border-bottom: 2px dashed rgba(143,43,29,0.3);
}

.retire-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.retire-section > p {
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.85;
  color: #3a2a18;
}

.retire-guide {
  padding: 12px 14px;
  background: rgba(255,255,255,0.5);
  border-left: 4px solid #c8a030;
  margin: 16px 0 !important;
}

.retire-warning {
  padding: 12px 16px;
  background: #fff8f3;
  border: 2px solid #b32025;
  border-radius: 3px;
  font-weight: 700;
  color: #7a1010;
  text-align: center;
  box-shadow: 2px 2px 0 rgba(179,32,37,0.15);
  margin: 16px 0 !important;
}

.section-title {
  margin: 0 0 16px;
  padding: 10px 14px;
  font-size: 17px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-left: 5px solid #e8c96a;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  line-height: 1.5;
}

.carrier-check-note {
  margin: 0 0 16px;
  padding: 12px 16px;
  background: linear-gradient(transparent 70%, #ffeb3b 70%);
  font-size: 14px;
  font-weight: 700;
  color: #3a2a18;
  text-align: center;
  line-height: 1.7;
}

.carrier-title {
  margin: 16px 0 14px;
  font-size: 15px;
  font-weight: 900;
  color: #1a0a04;
  text-align: center;
  letter-spacing: 0.08em;
}

.carrier-box {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0 0 24px;
}

.carrier-item {
  border: 3px solid;
  border-radius: 0;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.2);
  overflow: hidden;
}

.carrier-header {
  padding: 10px 14px;
  font-size: 15px;
  font-weight: 900;
  color: #fff;
  letter-spacing: 0.08em;
  text-align: center;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.carrier-body {
  padding: 14px 16px;
  background: #fffdf5;
  font-size: 13px;
  line-height: 1.8;
  color: #3a2a18;
}

.carrier-au {
  border-color: #993d00;
}

.carrier-au .carrier-header {
  background: linear-gradient(135deg, #ff6600 0%, #cc5200 100%);
}

.carrier-docomo {
  border-color: #660011;
}

.carrier-docomo .carrier-header {
  background: linear-gradient(135deg, #cc0033 0%, #990022 100%);
}

.carrier-softbank {
  border-color: #004466;
}

.carrier-softbank .carrier-header {
  background: linear-gradient(135deg, #0099cc 0%, #006699 100%);
}

.retire_button {
  margin: 24px 0 0;
  text-align: center;
}

.btn-flat-border {
  display: inline-block;
  width: 100%;
  max-width: 280px;
  padding: 16px 24px;
  background: linear-gradient(135deg, #6a5030 0%, #4a3520 100%);
  color: #f5ede0 !important;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none !important;
  border: 3px solid #2a1a0e;
  border-radius: 0;
  box-shadow: 4px 4px 0 rgba(42,26,14,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
  position: relative;
}

.btn-flat-border::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(245,237,224,0.2);
  pointer-events: none;
}

.btn-flat-border:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 rgba(42,26,14,0.3);
}

.ad-space {
  margin: 24px 0;
  text-align: center;
  padding: 20px 0;
  border-top: 1px solid rgba(143,43,29,0.2);
  border-bottom: 1px solid rgba(143,43,29,0.2);
}

/* ---------- ãƒ›ã?ãƒ?ã¸æˆ»ã‚‹ã?ã‚¿ãƒ³?ˆã?ãƒ¼ã‚¸ä¸‹éƒ¨??---------- */
.btn-home-wrap {
  text-align: center;
  margin-top: 32px;
  padding-top: 28px;
  border-top: 2px solid rgba(200,160,48,0.3);
  position: relative;
}

.btn-home-wrap::before {
  content: "\25C6";
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  font-size: 10px;
  color: #c8a030;
  background: #fffdf7;
  padding: 0 8px;
}

.btn-home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 12px 28px 12px 24px;
  background: #fffdf5;
  border: 2px solid #2a1a0e;
  border-radius: 3px;
  font-size: 14px;
  font-weight: 700;
  color: #2a1a0e;
  letter-spacing: 0.08em;
  text-decoration: none;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.25);
  position: relative;
  transition: transform 0.1s, box-shadow 0.1s;
}

/* å†??äºŒé‡ç·?*/
.btn-home::before {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid rgba(42,26,14,0.15);
  pointer-events: none;
}

/* çŸ¢å° */
.btn-home::after {
  content: "\25C4";
  font-size: 10px;
  color: #2a1a0e;
  opacity: 0.7;
}

.btn-home:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(42,26,14,0.25);
}

/* ---------- ãŠçŸ¥ã‚‰ã›ãƒ»ã‚¨ãƒ©ãƒ¼ã‚¨ãƒªã‚¢ ---------- */
.sub-notice {
  margin-bottom: 4px;
}

.notice, .alert, .error, .flash, .info {
  padding: 11px 14px 11px 34px;
  border-radius: 3px;
  margin-bottom: 16px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.02em;
  position: relative;
  border: 2px solid #8f2b1d;
  background: #fff8f3;
  color: #7a1010;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.15);
}

.notice::before, .alert::before, .error::before, .flash::before, .info::before {
  content: "\25C6";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 8px;
  color: #b32025;
}

/* ---------- h2è¦‹å?ã—ï¼ˆæ˜­å’Œãƒ¬ãƒˆãƒ­çœ‹æ¿é¢¨??---------- */
.sub-main h2 {
  margin: 20px 0 18px;
  font-size: 14px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.14em;
  line-height: 1.4;
  padding: 14px 18px;
  background: #f5ede0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  border: 3px solid #2a1a0e;
  border-radius: 0;
  box-shadow: 4px 4px 0 rgba(42,26,14,0.35);
  position: relative;
  text-shadow: 1px 1px 0 rgba(255,255,255,0.5);
}

/* å·¦ä¸Šãƒ“ã‚¹ */
.sub-main h2::before {
  content: "\25C6";
  position: absolute;
  top: 6px;
  left: 8px;
  font-size: 7px;
  color: #2a1a0e;
  opacity: 0.5;
}

/* å³ä¸Šãƒ“ã‚¹ */
.sub-main h2::after {
  content: "\25C6";
  position: absolute;
  top: 6px;
  right: 8px;
  font-size: 7px;
  color: #2a1a0e;
  opacity: 0.5;
}

/* ä¸‹ãƒ“ã‚¹ç”¨ã®è¿½åŠ?æ“¬ä¼¼è¦ç´?ã¯spanã§å¯¾å¿?*/

/* ---------- .qa?ˆã‚ˆãã‚ã‚‹è³ªå•ã‚¨ãƒªã‚¢??---------- */
.qa {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 1.85;
  color: #3a2a18;
  background: #f5ede0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  border: 3px solid #8f2b1d;
  border-radius: 4px;
  padding: 20px 16px 24px;
  box-shadow:
    3px 3px 0 rgba(143,43,29,0.2),
    0 6px 18px rgba(0,0,0,0.08);
  position: relative;
}

/* å››éš…ãƒ“ã‚¹ */
.qa::before {
  content: "\25C6";
  position: absolute;
  top: 7px; left: 9px;
  font-size: 8px; color: #8f2b1d; opacity: 0.5;
}

.qa::after {
  content: "\25C6";
  position: absolute;
  top: 7px; right: 9px;
  font-size: 8px; color: #8f2b1d; opacity: 0.5;
}

.qa h3 {
  margin: 28px 0 14px;
  padding: 12px 16px 12px 50px;
  font-size: 16px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.06em;
  line-height: 1.5;
  background: #fffdf5;
  border: 2px solid #2a1a0e;
  border-left: 6px solid #b32025;
  border-radius: 0;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.25);
  position: relative;
  text-shadow: 1px 1px 0 rgba(255,255,255,0.4);
}

.qa h3::before {
  content: "Q";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  font-weight: 900;
  color: #b32025;
  font-family: Georgia, serif;
  text-shadow: 1px 1px 0 rgba(255,255,255,0.3);
}

/* ãƒ“ã‚¹è£?£¾ */
.qa h3::after {
  content: "\25C6";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 7px;
  color: #2a1a0e;
  opacity: 0.4;
}

.qa h3:first-child {
  margin-top: 0;
}

/* å›žç­”ãƒ†ã‚­ã‚¹ãƒˆã‚¨ãƒªã‚¢ */
.qa > *:not(h3) {
  margin-left: 0;
  margin-bottom: 12px;
  padding: 8px 14px;
  background: rgba(255,255,255,0.4);
  border-left: 3px solid #c8a030;
  line-height: 1.9;
}

.qa br {
  display: block;
  content: "";
  margin-top: 6px;
}

.qa p {
  margin: 8px 0;
  padding: 8px 14px;
  background: rgba(255,255,255,0.4);
  border-left: 3px solid #c8a030;
  line-height: 1.9;
}

/* ---------- selectè¦ç´??ˆãŠå•ã„åˆã‚ã›æ–¹æ³•é¸æŠžï¼?---------- */
dl select#main_product {
  padding: 12px 14px;
  border: 2px solid #c8a030;
  border-radius: 3px;
  background: #fffdf5;
  font-size: 15px;
  font-family: inherit;
  color: #2b2b2b;
  outline: none;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
}

dl select#main_product:focus {
  border-color: #b32025;
  box-shadow: 0 0 0 3px rgba(179,32,37,0.12);
}

/* ============================================================
   ã‚³ãƒ³ãƒ?ƒ³ãƒ?ƒ–ãƒ­ãƒ?‚¯?ˆãƒ•ã‚©ãƒ¼ãƒ?ãƒ©ãƒ?ƒ‘ãƒ¼??   ============================================================ */
.contents {
  background: #f5ede0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  border: 2px solid #8f2b1d;
  border-radius: 4px;
  padding: 22px 16px 24px;
  margin: 14px 0 24px;
  box-shadow:
    3px 3px 0 rgba(143,43,29,0.2),
    0 6px 18px rgba(0,0,0,0.08);
  position: relative;
}

.contents::before {
  content: "\25C6";
  position: absolute;
  top: 6px; left: 8px;
  font-size: 7px; color: #8f2b1d; opacity: 0.45;
}

.contents::after {
  content: "\25C6";
  position: absolute;
  top: 6px; right: 8px;
  font-size: 7px; color: #8f2b1d; opacity: 0.45;
}

/* ---------- ãƒ•ã‚©ãƒ¼ãƒ? ---------- */
form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.contents input[type="text"],
.contents input[type="email"],
.contents input[type="password"],
.contents input[type="tel"],
.contents select,
.contents textarea {
  display: block;
  width: 100%;
  padding: 11px 13px;
  border: 2px solid #c8a030;
  border-radius: 3px;
  background: #fffdf5;
  font-size: 15px;
  font-family: inherit;
  color: #2b2b2b;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.contents input[type="text"]:focus,
.contents input[type="email"]:focus,
.contents input[type="password"]:focus,
.contents input[type="tel"]:focus,
.contents select:focus,
.contents textarea:focus {
  border-color: #b32025;
  box-shadow: 0 0 0 3px rgba(179,32,37,0.12);
}

.contents textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.7;
}

.contents label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #3a2a18;
  cursor: pointer;
  line-height: 1.5;
}

.contents input[type="radio"],
.contents input[type="checkbox"] {
  accent-color: #b32025;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  cursor: pointer;
}

/* ---------- ä¼šå“¡ç™»éŒ²ãƒœã‚¿ãƒ³?ˆå¤§??---------- */
.download_button {
  text-align: center;
  padding: 8px 0;
}

.btn-regist {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 280px;
  padding: 16px 20px;
  background: linear-gradient(135deg, #d42e22 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-align: center;
  text-decoration: none !important;
  border: 3px solid #e8c96a;
  border-radius: 5px;
  box-shadow:
    3px 3px 0 rgba(100,10,10,0.4),
    0 6px 24px rgba(179,32,37,0.35);
  position: relative;
  min-height: 58px;
  transition: transform 0.1s, box-shadow 0.1s, filter 0.1s;
  animation: btnPulse 2.4s ease-in-out infinite;
  box-sizing: border-box;
  line-height: 1.4;
}

.btn-regist::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(232,201,106,0.45);
  border-radius: 3px;
  pointer-events: none;
}

.btn-regist:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(100,10,10,0.4);
  animation: none;
}

/* ---------- é€?ä¼šç¢ºèªã?ã‚¿ãƒ³ ---------- */
.retire-buttons {
  margin: 32px 0 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
}

.taikai_no,
.taikai_yes {
  width: 100%;
  max-width: 300px;
}

.taikai_no a,
.taikai_yes a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 16px 20px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none !important;
  border-radius: 5px;
  position: relative;
  min-height: 56px;
  transition: transform 0.1s, box-shadow 0.1s;
  box-sizing: border-box;
  line-height: 1.4;
}

/* é€?ä¼šã—ãªã?¼ˆæŽ¨å¥¨ãƒ»æ˜Žã‚‹ã?¼?*/
.taikai_no a {
  background: linear-gradient(135deg, #d42e22 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  border: 3px solid #e8c96a;
  box-shadow:
    3px 3px 0 rgba(100,10,10,0.4),
    0 4px 18px rgba(179,32,37,0.28);
  animation: btnPulse 2.4s ease-in-out infinite;
}

.taikai_no a::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(232,201,106,0.4);
  border-radius: 3px;
  pointer-events: none;
}

.taikai_no a:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(100,10,10,0.4);
  animation: none;
}

/* é€?ä¼šã™ã‚‹ï¼ˆæŽ§ãˆã‚ãƒ»ã‚°ãƒ¬ãƒ¼??*/
.taikai_yes a {
  background: #6a5030;
  color: #f5ede0 !important;
  border: 2px solid #3a2a18;
  box-shadow: 2px 2px 0 rgba(42,26,14,0.3);
}

.taikai_yes a::after {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid rgba(245,237,224,0.2);
  border-radius: 3px;
  pointer-events: none;
}

.taikai_yes a:active {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 rgba(42,26,14,0.3);
}

/* ---------- ãƒªãƒ³ã‚¯ãƒªã‚¹ãƒ?---------- */
.link-list {
  margin: 16px 0;
}

.link-list p {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  color: #3a2a18;
  line-height: 1.7;
  padding-left: 4px;
}

.link-list p:last-child {
  margin-bottom: 0;
}

.link-list a {
  margin-left: 8px;
}

/* ---------- é€ä¿¡ãƒœã‚¿ãƒ³ ---------- */
input[type="submit"],
button[type="submit"] {
  display: block;
  width: 100%;
  padding: 15px 20px;
  background: linear-gradient(135deg, #d42e22 0%, #8d1a12 100%);
  color: #fff7d6;
  font-size: 16px;
  font-weight: 900;
  font-family: inherit;
  letter-spacing: 0.1em;
  text-align: center;
  border: 2px solid #e8c96a;
  border-radius: 4px;
  cursor: pointer;
  box-shadow:
    3px 3px 0 rgba(100,10,10,0.4),
    0 4px 18px rgba(179,32,37,0.28);
  -webkit-appearance: none;
  appearance: none;
  position: relative;
  min-height: 52px;
  transition: transform 0.1s, box-shadow 0.1s, filter 0.1s;
  animation: btnPulse 2.4s ease-in-out infinite;
}

/* å†??ãƒ©ã‚¤ãƒ³ */
input[type="submit"]::after,
button[type="submit"]::after {
  content: "";
  position: absolute;
  inset: 3px;
  border: 1px solid rgba(232,201,106,0.4);
  border-radius: 2px;
  pointer-events: none;
}

input[type="submit"]:active,
button[type="submit"]:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(100,10,10,0.4);
  animation: none;
}

@keyframes neonFlicker {
  0%, 19%, 21%, 23%, 100% { opacity: 1; }
  20%                      { opacity: 0.7; }
  22%                      { opacity: 0.4; }
}

@keyframes blinkLight {
  0%, 100% { opacity: 1; }
  45%       { opacity: 1; }
  50%       { opacity: 0.2; }
  55%       { opacity: 1; }
}

@keyframes cardShine {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

@keyframes btnPulse {
  0%, 100% { box-shadow: 3px 3px 0 rgba(100,10,10,0.4), 0 0 0 0 rgba(232,201,106,0); }
  50%       { box-shadow: 3px 3px 0 rgba(100,10,10,0.4), 0 0 18px 4px rgba(232,201,106,0.4); }
}

/* ---------- æ°´å¹³ç·?---------- */
hr {
  border: none;
  border-top: 2px solid rgba(200,160,48,0.45);
  margin: 24px 0;
  position: relative;
}

hr::before {
  content: "\25C6";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size: 10px;
  color: #c8a030;
  background: #fffdf7;
  padding: 0 8px;
}

/* ---------- ãƒªãƒ³ã‚¯ ---------- */
.sub-main a:not(.btn-home):not(.btn-regist) {
  color: #b32025;
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* ãƒœã‚¿ãƒ³å†?ƒªãƒ³ã‚¯ã¯é™¤å¤?*/
.taikai_no a,
.taikai_yes a {
  text-decoration: none !important;
}

/* ---------- ãƒ•ãƒƒã‚¿ãƒ¼ä½™ç™½ ---------- */
.sub-footer-space {
  min-height: 20px;
}

/* ---------- ã‚µãƒ–ã?ãƒ¼ã‚¸å…±é€šãƒ•ãƒ?‚¿ãƒ¼ ---------- */
.footer_wrap {
  background: #1a0a04;
  border-top: 3px solid #8f2b1d;
  padding: 28px 16px 20px;
}

.footer_list {
  list-style: none;
  margin: 0 0 20px;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid rgba(200,160,48,0.2);
  border-radius: 4px;
  overflow: hidden;
}

.footer_list li {
  border-bottom: 1px solid rgba(200,160,48,0.15);
  border-right: 1px solid rgba(200,160,48,0.15);
}

.footer_list li:nth-child(even) {
  border-right: none;
}

.footer_list li a {
  display: block;
  padding: 11px 12px 11px 18px;
  font-size: 12px;
  font-weight: 700;
  color: #f5e6c8;
  text-decoration: none;
  letter-spacing: 0.03em;
  position: relative;
}

.footer_list li a::before {
  content: "\25C6";
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 6px;
  color: #c8a030;
}

.footer_copyright {
  text-align: center;
  font-size: 10px;
  color: rgba(245,230,200,0.4);
  letter-spacing: 0.05em;
  padding-top: 16px;
  border-top: 1px solid rgba(200,160,48,0.15);
}

/* ---------- é€?ä¼šå®Œäº??ãƒ¼ã‚¸??ai04_x_sp_1.html??---------- */
.thanks-message-center {
  margin: 0 0 24px;
  padding: 18px;
  background: rgba(255,255,255,0.6);
  border: 3px solid #b32025;
  border-radius: 3px;
  text-align: center;
  box-shadow: 2px 2px 0 rgba(179,32,37,0.15);
  font-size: 16px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.06em;
  line-height: 1.8;
}

.retire-complete-section {
  margin: 0;
}

.retire-complete-section > p {
  margin: 0 0 20px;
  font-size: 14px;
  line-height: 1.85;
  color: #3a2a18;
}

.retire-status-table {
  margin: 24px auto;
  border-radius: 0;
  border: 3px solid #2a1a0e;
  border-spacing: 0;
  overflow: hidden;
  box-shadow: 4px 4px 0 rgba(42,26,14,0.3);
  width: 100%;
  background: #fffdf5;
  display: block;
}

.retire-status-table tbody {
  display: block;
  width: 100%;
}

.retire-status-table tr {
  display: flex;
  width: 100%;
  border-bottom: 2px solid #2a1a0e;
}

.retire-status-table tr:last-child {
  border-bottom: none;
}

.retire-status-table th,
.retire-status-table td {
  padding: 12px 10px;
  font-size: 13px;
  line-height: 1.6;
  word-break: break-all;
}

.retire-status-table th {
  flex: 0 0 40%;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
  text-align: left;
  border-right: 2px solid #2a1a0e;
}

.retire-status-table td {
  flex: 1;
  color: #3a2a18;
  font-weight: 700;
  background: #fffdf5;
  text-align: left;
  padding-left: 14px;
}

.small-text {
  font-size: 12px !important;
  line-height: 1.8 !important;
  color: #3a2a18 !important;
}

.carrier-guide-text {
  margin: 8px 0 0;
  font-size: 11px;
  line-height: 1.8;
  color: #3a2a18;
}

.retire-link {
  color: #0000b3 !important;
  text-decoration: none !important;
  font-weight: 700;
  padding: 2px 4px;
  background: rgba(0,0,179,0.1);
  border-radius: 2px;
}

/* ---------- é€?ä¼šã‚¢ãƒ³ã‚±ãƒ¼ãƒˆã?ãƒ¼ã‚¸??ai03_sp_1.html??---------- */
.survey-note {
  margin: 0 0 24px;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.75;
  color: #3a2a18;
  background: rgba(255,255,255,0.5);
  border: 2px solid #c8a030;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(200,160,48,0.2);
}

/* ã‚­ãƒ£ãƒªã‚¢é¸æŠžã?ã‚¿ãƒ³??ai01_sp_1.html??*/
.select-carrier {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0 0 28px;
}

.carrier-radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.carrier-label-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 900;
  color: #fff;
  border: 3px solid;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.2);
  cursor: pointer;
  transition: all 0.2s;
  text-align: center;
  position: relative;
  box-sizing: border-box;
}

.carrier-label-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}

.carrier-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  font-size: 14px;
  font-weight: 900;
  background: rgba(255,255,255,0.3);
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.5);
}

.carrier-name {
  font-size: 16px;
  letter-spacing: 0.08em;
}

/* docomo */
.carrier-docomo-btn {
  background: linear-gradient(135deg, #cc0033 0%, #990022 100%);
  border-color: #660011;
  color: #fff;
  opacity: 0.6;
}

.carrier-radio:checked + .carrier-docomo-btn {
  opacity: 1;
  box-shadow: 3px 3px 0 rgba(102,0,17,0.3), 0 0 0 3px rgba(204,0,51,0.3);
}

/* au */
.carrier-au-btn {
  background: linear-gradient(135deg, #ff6600 0%, #cc5200 100%);
  border-color: #993d00;
  color: #fff;
  opacity: 0.6;
}

.carrier-radio:checked + .carrier-au-btn {
  opacity: 1;
  box-shadow: 3px 3px 0 rgba(153,61,0,0.3), 0 0 0 3px rgba(255,102,0,0.3);
}

/* softbank */
.carrier-softbank-btn {
  background: linear-gradient(135deg, #0099cc 0%, #006699 100%);
  border-color: #004466;
  color: #fff;
  opacity: 0.6;
}

.carrier-radio:checked + .carrier-softbank-btn {
  opacity: 1;
  box-shadow: 3px 3px 0 rgba(0,68,102,0.3), 0 0 0 3px rgba(0,153,204,0.3);
}

.retire-survey-title {
  margin: 0 0 12px;
  padding: 12px 16px;
  font-size: 16px;
  font-weight: 900;
  color: #1a0a04;
  letter-spacing: 0.08em;
  background: rgba(255,255,255,0.5);
  border-left: 5px solid #b32025;
  border-bottom: 2px solid rgba(179,32,37,0.2);
  line-height: 1.6;
}

.select-wrap {
  margin: 0 0 28px;
}

.select-wrap select {
  width: 100%;
  padding: 14px 40px 14px 16px;
  font-size: 15px;
  font-weight: 700;
  color: #3a2a18;
  background: #fffdf5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23b32025' d='M0 0l6 8 6-8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px;
  border: 3px solid #2a1a0e;
  border-radius: 0;
  box-shadow: 2px 2px 0 rgba(42,26,14,0.2);
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.select-wrap select:focus {
  outline: none;
  border-color: #b32025;
  box-shadow: 2px 2px 0 rgba(42,26,14,0.2), 0 0 0 2px rgba(179,32,37,0.2);
}

.radio-wrap {
  margin: 0 0 24px;
  padding: 16px;
  background: rgba(255,255,255,0.3);
  border: 2px solid rgba(42,26,14,0.15);
  border-radius: 3px;
}

.label-radio {
  display: block;
  margin: 0 0 14px;
  padding: 12px 16px;
  background: #fffdf5;
  border: 2px solid #2a1a0e;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
}

.label-radio:last-child {
  margin-bottom: 0;
}

.label-radio:hover {
  background: #fff7e8;
  border-color: #b32025;
}

.label-radio input[type="radio"] {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.label-radio input[type="radio"]:checked + .lever {
  color: #b32025;
  font-weight: 900;
}

.label-radio input[type="radio"]:checked + .lever::before {
  background: #b32025;
  border-color: #b32025;
}

.label-radio input[type="radio"]:checked + .lever::after {
  opacity: 1;
}

.lever {
  display: block;
  padding-left: 32px;
  font-size: 15px;
  font-weight: 700;
  color: #3a2a18;
  letter-spacing: 0.05em;
  line-height: 1.5;
  position: relative;
  transition: color 0.2s;
}

.lever::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border: 3px solid #2a1a0e;
  border-radius: 50%;
  background: #fff;
  transition: all 0.2s;
}

.lever::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  opacity: 0;
  transition: opacity 0.2s;
}

.survey-textarea-wrap {
  margin: 0 0 24px;
}

.survey-textarea {
  width: 100%;
  min-height: 180px;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.8;
  color: #3a2a18;
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 0;
  box-shadow: inset 2px 2px 4px rgba(42,26,14,0.1);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  resize: vertical;
}

.survey-textarea:focus {
  outline: none;
  border-color: #b32025;
  box-shadow: inset 2px 2px 4px rgba(42,26,14,0.1), 0 0 0 2px rgba(179,32,37,0.2);
}

/* ---------- ã‚³ãƒ³ãƒ?ƒ³ãƒ?¸?è¦§ãƒšã?ã‚¸??ist_sp_1.html??---------- */
#content {
  width: 100%;
}

.msg {
  margin: 0 0 20px;
  padding: 14px 18px;
  font-size: 14px;
  line-height: 1.75;
  color: #3a2a18;
  background: rgba(255,255,255,0.5);
  border-left: 4px solid #c8a030;
  border-radius: 3px;
}

.not-found-message {
  padding: 40px 20px !important;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  color: #7a1010;
  line-height: 1.8;
}

.content_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin: 0 0 24px;
  padding: 0;
  list-style: none;
}

.content-item {
  list-style: none;
  margin: 0;
  padding: 0;
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.3);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.content-img-wrap {
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, #f7f1e4 0%, #eddcc4 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-bottom: 2px solid #2a1a0e;
  position: relative;
  -webkit-user-select: none;
  user-select: none;
}

.content-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  pointer-events: none;
  -webkit-user-drag: none;
}

.content-name {
  padding: 8px 10px;
  font-size: 11px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.5;
  text-align: center;
  word-break: break-all;
  flex: 1;
}

.btn-list-download {
  display: block;
  margin: 0 8px 10px;
  padding: 9px 6px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-align: center;
  text-decoration: none !important;
  border: 2px solid #7a1010;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(122,16,16,0.3);
  box-sizing: border-box;
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-list-download:active {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 rgba(122,16,16,0.3);
}

/* ã‚¹ãƒžã?å°ç”»é¢å¯¾å¿?*/
@media (max-width: 360px) {
  .content_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  
  .content-name {
    font-size: 12px;
    padding: 8px 10px;
    min-height: 55px;
  }
}

/* ---------- ãƒžã‚¤ãƒšã?ã‚¸??ypage_sp_1.html??---------- */
.mypage-points {
  margin: 0 0 20px;
  padding: 18px 20px;
  background: linear-gradient(135deg, #fff7d6 0%, #ffe8a0 100%);
  border: 3px solid #c8a030;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(200,160,48,0.3);
  text-align: center;
}

.points-label {
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  margin: 0 0 8px;
  letter-spacing: 0.05em;
}

.points-value {
  font-size: 22px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.08em;
  text-shadow: 1px 1px 0 rgba(179,32,37,0.2);
}

.mypage-count {
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 700;
  color: #3a2a18;
  text-align: center;
  background: rgba(255,255,255,0.5);
  border: 2px solid rgba(42,26,14,0.1);
  border-radius: 3px;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.mypage-history-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin: 20px 0 24px;
}

.history-item {
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.3);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.history-thumbnail {
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, #f7f1e4 0%, #eddcc4 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-bottom: 2px solid #2a1a0e;
  position: relative;
}

.history-thumbnail::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  pointer-events: none;
}

.history-img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  -webkit-user-select: none;
  user-select: none;
}

.history-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  position: relative;
  z-index: 1;
  pointer-events: none;
  -webkit-user-drag: none;
}

.sample-label {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-25deg);
  font-size: 20px;
  font-weight: 900;
  color: rgba(255,255,255,0.75);
  letter-spacing: 0.2em;
  text-shadow:
    1px 1px 0 rgba(0,0,0,0.4),
    -1px -1px 0 rgba(0,0,0,0.2);
  z-index: 2;
  pointer-events: none;
  white-space: nowrap;
  border: 2px solid rgba(255,255,255,0.55);
  padding: 2px 8px;
  border-radius: 3px;
  background: rgba(0,0,0,0.15);
}

.history-name {
  padding: 10px 12px;
  font-size: 11px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.5;
  text-align: center;
  word-break: break-all;
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 2px solid rgba(42,26,14,0.1);
}

.history-download {
  padding: 10px;
}

.btn-download {
  display: block;
  padding: 10px 12px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-align: center;
  text-decoration: none !important;
  border: 2px solid #7a1010;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(122,16,16,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-download:active {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 rgba(122,16,16,0.3);
}

/* ã‚¹ãƒžã?å°ç”»é¢å¯¾å¿?*/
@media (max-width: 360px) {
  .mypage-history-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  
  .history-name {
    font-size: 10px;
    padding: 8px 10px;
    min-height: 45px;
  }
  
  .btn-download {
    font-size: 12px;
    padding: 8px 10px;
  }
}

/* ---------- è©³ç´°ãƒšã?ã‚¸??etail_sp_1.html??---------- */
.detail-edit-btn-wrap {
  margin: 0 0 16px;
  text-align: right;
}

.btn-edit-header {
  display: inline-block;
  padding: 8px 20px;
  background: linear-gradient(135deg, #c8a030 0%, #a08020 100%);
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none !important;
  border: 2px solid #806018;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(128,96,24,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-edit-header:active {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 rgba(128,96,24,0.3);
}

.detail-separator {
  margin: 24px 0;
  height: 2px;
  background: repeating-linear-gradient(
    90deg,
    rgba(179,32,37,0.3) 0px,
    rgba(179,32,37,0.3) 8px,
    transparent 8px,
    transparent 16px
  );
}

.content_subtitle {
  margin: 24px 0 16px;
  padding: 10px 16px;
  font-size: 15px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-left: 5px solid #e8c96a;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  line-height: 1.5;
}

.detail-table {
  width: 100%;
  margin: 0 0 0;
  border-collapse: collapse;
  background: transparent;
}

.detail-table tr {
  border-bottom: 2px solid rgba(42,26,14,0.1);
}

.detail-table tr:last-child {
  border-bottom: none;
}

.detail-table th {
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 900;
  color: #3a2a18;
  text-align: left;
  background: rgba(255,255,255,0.3);
  border-right: 2px solid rgba(42,26,14,0.1);
  vertical-align: top;
  width: 35%;
  letter-spacing: 0.05em;
}

.detail-table td {
  padding: 12px 14px;
  font-size: 14px;
  font-weight: 500;
  color: #3a2a18;
  text-align: left;
  line-height: 1.7;
  word-break: break-all;
}

.detail-action-buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 28px 0 0;
  padding: 20px 0 0;
  border-top: 2px dashed rgba(179,32,37,0.3);
}

.btn-detail-action {
  width: 100%;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.1em;
  border: 3px solid;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(0,0,0,0.2);
  cursor: pointer;
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-detail-action:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}

.btn-detail-edit {
  background: linear-gradient(135deg, #c8a030 0%, #a08020 100%);
  border-color: #806018;
  color: #fff;
}

.btn-detail-destroy {
  background: linear-gradient(135deg, #6a5030 0%, #4a3520 100%);
  border-color: #2a1a0e;
  color: #f5ede0;
}

.detail-link-section {
  margin: 20px 0 0;
  padding: 20px 0 0;
  border-top: 2px dashed rgba(179,32,37,0.3);
}

.detail-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.detail-link-list li {
  margin: 0 0 10px;
  padding: 0;
}

.detail-link-list li:last-child {
  margin-bottom: 0;
}

.detail-link-list a {
  display: block;
  padding: 12px 16px 12px 40px;
  background: rgba(255,255,255,0.3);
  border: 2px solid rgba(42,26,14,0.2);
  border-radius: 3px;
  color: #b32025 !important;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none !important;
  position: relative;
  transition: all 0.2s;
  letter-spacing: 0.05em;
}

.detail-link-list a::before {
  content: "\25C4";
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: #b32025;
  font-size: 12px;
}

.detail-link-list a:hover {
  background: rgba(179,32,37,0.1);
  border-color: #b32025;
}

/* ---------- ãƒ?ã‚¦ãƒ³ãƒ­ãƒ¼ãƒ‰è©³ç´°ãƒšã?ã‚¸??etail_img_sp_1.html??---------- */
.debug-info {
  margin: 0 0 20px;
  padding: 12px 14px;
  background: rgba(0,0,0,0.05);
  border: 1px solid rgba(0,0,0,0.1);
  font-size: 11px;
  line-height: 1.6;
  color: #666;
  border-radius: 3px;
}

.download-preview {
  text-align: center;
  margin: 0 0 24px;
}

.preview-image {
  margin: 0 0 16px;
  padding: 16px;
  background: linear-gradient(135deg, #f7f1e4 0%, #eddcc4 100%);
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.3);
  display: inline-block;
  position: relative;
}

.preview-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23eddcc4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23d4b896' opacity='0.4'/%3E%3Crect x='2' y='1' width='1' height='1' fill='%23c8a87a' opacity='0.25'/%3E%3Crect x='1' y='3' width='1' height='1' fill='%23d4b896' opacity='0.3'/%3E%3C/svg%3E");
  pointer-events: none;
  border-radius: 3px;
}

.preview-image img {
  display: block;
  max-width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
}

.download-points {
  font-size: 16px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.08em;
  padding: 12px;
  background: rgba(255,255,255,0.5);
  border: 2px solid rgba(179,32,37,0.3);
  border-radius: 3px;
  display: inline-block;
}

.download-button-wrap {
  margin: 0 0 16px;
  text-align: center;
}

.btn-download-main {
  display: inline-block;
  padding: 18px 40px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-align: center;
  text-decoration: none !important;
  border: 3px solid #7a1010;
  border-radius: 3px;
  box-shadow: 4px 4px 0 rgba(122,16,16,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
  position: relative;
}

.btn-download-main::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid rgba(255,247,214,0.3);
  pointer-events: none;
  border-radius: 1px;
}

.btn-download-main:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 rgba(122,16,16,0.3);
}

.download-instruction {
  margin: 0 0 20px;
  padding: 12px 16px;
  font-size: 13px;
  line-height: 1.7;
  color: #3a2a18;
  text-align: center;
  background: rgba(255,255,255,0.5);
  border: 2px solid rgba(42,26,14,0.1);
  border-radius: 3px;
}

.point-shortage {
  margin: 0 0 20px;
  padding: 20px;
  background: rgba(255,235,235,0.5);
  border: 3px solid #b32025;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(179,32,37,0.2);
  text-align: center;
}

.current-points {
  margin: 0 0 16px;
  padding: 16px;
  background: linear-gradient(135deg, #fff7d6 0%, #ffe8a0 100%);
  border: 2px solid #c8a030;
  border-radius: 3px;
}

.points-label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  margin: 0 0 6px;
}

.points-value {
  display: block;
  font-size: 24px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.08em;
}

.shortage-message {
  margin: 0 0 16px;
  font-size: 15px;
  font-weight: 700;
  color: #7a1010;
  line-height: 1.7;
}

.point-add-btn-wrap {
  margin: 0;
}

.btn-point-add {
  display: inline-block;
  padding: 14px 32px;
  background: linear-gradient(135deg, #c8a030 0%, #a08020 100%);
  color: #fff !important;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-decoration: none !important;
  border: 3px solid #806018;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(128,96,24,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-point-add:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(128,96,24,0.3);
}

.download-confirm {
  margin: 20px 0 0;
  padding: 16px 20px;
  font-size: 12px;
  line-height: 1.8;
  color: #3a2a18;
  text-align: center;
  background: rgba(255,255,255,0.3);
  border: 2px dashed rgba(42,26,14,0.3);
  border-radius: 3px;
}

/* ---------- éŸ³æ¥½ãƒ?ã‚¦ãƒ³ãƒ­ãƒ¼ãƒ‰è©³ç´°ãƒšã?ã‚¸??etail_fla_utas_sp_1.html??---------- */
.music-title {
  margin: 0 0 20px;
  padding: 14px 18px;
  font-size: 17px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-left: 5px solid #e8c96a;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  line-height: 1.6;
  text-align: center;
}

.music-info {
  margin: 0 0 24px;
}

.music-info-table {
  width: 100%;
  border-collapse: collapse;
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.3);
}

.music-info-table tr {
  border-bottom: 2px solid #2a1a0e;
}

.music-info-table tr:last-child {
  border-bottom: none;
}

.music-info-table th {
  padding: 14px 12px;
  font-size: 13px;
  font-weight: 900;
  color: #fff7d6;
  text-align: left;
  background: linear-gradient(135deg, #6a5030 0%, #4a3520 100%);
  border-right: 2px solid #2a1a0e;
  vertical-align: middle;
  width: 40%;
  letter-spacing: 0.05em;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.music-info-table td {
  padding: 14px 12px;
  font-size: 14px;
  font-weight: 700;
  color: #3a2a18;
  text-align: left;
  line-height: 1.7;
  word-break: break-all;
  background: #fffdf5;
}

.music-info-table .point-value {
  font-size: 18px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.05em;
}

/* ---------- é€?ä¼šå®Œäº??ãƒ¼ã‚¸??etire_ok_sp_1.html??---------- */
.retire-complete-message {
  padding: 32px 20px;
  text-align: center;
}

.retire-complete-message p {
  margin: 0 0 16px;
  font-size: 16px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.retire-complete-message p:last-child {
  margin-bottom: 0;
}

/* ---------- é€?ä¼šã‚­ãƒ£ãƒ³ã‚»ãƒ«ãƒšã?ã‚¸??etire_ng_sp_1.html??---------- */
.retire-cancel-message {
  padding: 32px 20px 24px;
  text-align: center;
}

.retire-cancel-message p {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.retire-cancel-button {
  padding: 0 20px 20px;
  text-align: center;
}

.btn-to-top {
  display: inline-block;
  padding: 16px 40px;
  background: linear-gradient(135deg, #c8a030 0%, #a08020 100%);
  color: #fff !important;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none !important;
  border: 3px solid #806018;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(128,96,24,0.3);
  transition: transform 0.1s, box-shadow 0.1s;
}

.btn-to-top:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(128,96,24,0.3);
}

/* ---------- é€?ä¼šã?ãƒ¼ã‚¸??etire_mysoftbank_sp_1.html??---------- */
.retire-confirm-text {
  padding: 20px 18px;
  font-size: 15px;
  font-weight: 700;
  color: #3a2a18;
  text-align: center;
  line-height: 1.8;
  background: rgba(255,255,255,0.5);
  border: 2px solid rgba(179,32,37,0.3);
  border-radius: 3px;
  margin: 0 0 24px;
  letter-spacing: 0.05em;
}

.payment-method-title {
  padding: 14px 18px;
  font-size: 16px;
  font-weight: 900;
  color: #3a2a18;
  text-align: center;
  background: linear-gradient(135deg, #0099cc 0%, #006699 100%);
  color: #fff;
  border: 3px solid #004466;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(0,68,102,0.3);
  margin: 0 0 20px;
  letter-spacing: 0.08em;
}

.payment-method-docomo {
  background: linear-gradient(135deg, #cc0033 0%, #990022 100%);
  border-color: #660011;
  box-shadow: 3px 3px 0 rgba(102,0,17,0.3);
}

.payment-method-au {
  background: linear-gradient(135deg, #ff6600 0%, #cc5200 100%);
  border-color: #993d00;
  box-shadow: 3px 3px 0 rgba(153,61,0,0.3);
}

.course-list-title {
  margin: 0 0 16px;
  padding: 12px 16px;
  font-size: 16px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-left: 5px solid #e8c96a;
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  line-height: 1.5;
}

.course_list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.course-item {
  list-style: none;
  margin: 0;
  padding: 0;
}

.course-link {
  display: block;
  padding: 16px 18px;
  background: #fffdf5;
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.3);
  text-decoration: none !important;
  transition: transform 0.2s, box-shadow 0.2s;
}

.course-link:hover {
  transform: translateY(-2px);
  box-shadow: 3px 5px 0 rgba(42,26,14,0.3);
}

.course-link:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 rgba(42,26,14,0.3);
}

.course-processing {
  padding: 16px 18px;
  background: rgba(255,235,235,0.5);
  border: 3px solid #b32025;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(179,32,37,0.2);
}

.course-payment {
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  margin: 0 0 8px;
  letter-spacing: 0.05em;
}

.course-amount {
  font-size: 18px;
  font-weight: 900;
  color: #b32025;
  margin: 0 0 12px;
  letter-spacing: 0.05em;
}

.course-action {
  font-size: 15px;
  font-weight: 900;
  color: #b32025;
  text-align: center;
  padding: 10px;
  background: rgba(179,32,37,0.1);
  border: 2px solid rgba(179,32,37,0.3);
  border-radius: 3px;
  letter-spacing: 0.08em;
}

.course-status-processing {
  font-size: 15px;
  font-weight: 900;
  color: #b32025;
  margin: 0 0 8px;
  text-align: center;
  letter-spacing: 0.05em;
}

.course-note {
  font-size: 13px;
  font-weight: 700;
  color: #7a1010;
  text-align: center;
  line-height: 1.6;
}

.course-price-info {
  font-size: 14px;
  font-weight: 700;
  color: #3a2a18;
  margin: 0 0 12px;
  text-align: center;
  line-height: 1.7;
}

.course-cancel-note {
  font-size: 12px;
  font-weight: 700;
  color: #b32025;
  margin: 0 0 12px;
  padding: 8px 10px;
  background: rgba(255,235,235,0.6);
  border: 1px solid rgba(179,32,37,0.3);
  border-radius: 3px;
  text-align: center;
  line-height: 1.6;
}

.no-course-message {
  padding: 40px 20px;
  font-size: 15px;
  font-weight: 700;
  color: #7a1010;
  text-align: center;
  background: rgba(255,255,255,0.5);
  border: 2px dashed rgba(179,32,37,0.3);
  border-radius: 3px;
}

/* ---------- ç™»éŒ²å¤±æ•—ã?ãƒ¼ã‚¸??egistered_sp_1.html??---------- */
.error-message-box {
  padding: 24px 20px;
  background: rgba(255,235,235,0.5);
  border: 3px solid #b32025;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(179,32,37,0.2);
  margin: 0 0 24px;
}

.error-message-box p {
  margin: 0 0 14px;
  font-size: 15px;
  font-weight: 700;
  color: #7a1010;
  line-height: 1.8;
  letter-spacing: 0.03em;
}

.error-message-box p:last-child {
  margin-bottom: 0;
}

.error-action-button {
  text-align: center;
}

/* ---------- ç™»éŒ²åˆ¶é™ã?ãƒ¼ã‚¸??egist_stop_sp_1.html??---------- */
.restriction-message {
  padding: 40px 24px;
  text-align: center;
}

.restriction-message p {
  margin: 0 0 18px;
  font-size: 16px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.8;
  letter-spacing: 0.05em;
}

.restriction-message p:last-child {
  margin-bottom: 0;
}

/* ---------- ç™»éŒ²å®Œäº??ãƒ¼ã‚¸??egist_ok_sp_1.html??---------- */
.regist-complete-celebration {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 28px 20px;
  background: linear-gradient(135deg, #fff7d6 0%, #ffe8a0 100%);
  border: 4px solid #c8a030;
  border-radius: 5px;
  box-shadow: 4px 4px 0 rgba(200,160,48,0.3);
  margin: 0 0 28px;
  position: relative;
}

.regist-complete-celebration::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 2px solid rgba(255,255,255,0.5);
  border-radius: 3px;
  pointer-events: none;
}

.celebration-icon {
  font-size: 32px;
  color: #e8c96a;
  text-shadow: 
    0 0 10px rgba(232,201,106,0.8),
    2px 2px 4px rgba(200,160,48,0.5);
  animation: sparkle 2s ease-in-out infinite;
}

@keyframes sparkle {
  0%, 100% {
    transform: scale(1) rotate(0deg);
    opacity: 1;
  }
  50% {
    transform: scale(1.2) rotate(180deg);
    opacity: 0.8;
  }
}

.celebration-message {
  flex: 1;
  text-align: center;
}

.celebration-title {
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.08em;
  line-height: 1.6;
  text-shadow: 1px 1px 0 rgba(179,32,37,0.2);
}

.celebration-text {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: #3a2a18;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.login-info-box {
  margin: 0 0 28px;
  padding: 24px 20px;
  background: #fffdf5;
  border: 4px double #b32025;
  border-radius: 5px;
  box-shadow: 4px 4px 0 rgba(179,32,37,0.2);
  position: relative;
}

.login-info-box::before {
  content: "\25C6";
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: 10px;
  color: #e8c96a;
}

.login-info-box::after {
  content: "\25C6";
  position: absolute;
  top: 8px;
  right: 8px;
  font-size: 10px;
  color: #e8c96a;
}

.login-info-title {
  margin: 0 0 16px;
  padding: 12px;
  font-size: 17px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.1em;
  text-align: center;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-radius: 3px;
  box-shadow: 2px 2px 0 rgba(143,43,29,0.2);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.login-info-note {
  margin: 0 0 20px;
  padding: 14px 16px;
  font-size: 13px;
  font-weight: 700;
  color: #7a1010;
  line-height: 1.7;
  background: rgba(255,235,235,0.5);
  border: 2px solid rgba(179,32,37,0.3);
  border-radius: 3px;
  text-align: center;
}

.login-info-details {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.login-info-item {
  padding: 16px;
  background: linear-gradient(135deg, #f7f1e4 0%, #eddcc4 100%);
  border: 3px solid #2a1a0e;
  border-radius: 3px;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.2);
}

.login-info-label {
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 900;
  color: #3a2a18;
  letter-spacing: 0.08em;
  text-align: center;
}

.login-info-value {
  padding: 12px 16px;
  font-size: 18px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.1em;
  text-align: center;
  background: #fff;
  border: 2px solid #b32025;
  border-radius: 3px;
  word-break: break-all;
  font-family: 'Courier New', monospace;
}

.regist-complete-action {
  text-align: center;
  margin: 0;
}

.btn-to-top-large {
  display: inline-block;
  padding: 18px 48px;
  background: linear-gradient(135deg, #c8a030 0%, #a08020 100%);
  color: #fff !important;
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-align: center;
  text-decoration: none !important;
  border: 4px solid #806018;
  border-radius: 5px;
  box-shadow: 4px 4px 0 rgba(128,96,24,0.4);
  transition: transform 0.1s, box-shadow 0.1s;
  position: relative;
}

.btn-to-top-large::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 2px solid rgba(255,255,255,0.3);
  pointer-events: none;
  border-radius: 2px;
}

.btn-to-top-large:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 rgba(128,96,24,0.4);
}

/* ---------- ç™»éŒ²ãƒšã?ã‚¸??egist_mysoftbank_sp_1.html??---------- */
.regist-note {
  margin: 0 0 16px;
  font-size: 12px;
  line-height: 1.8;
  color: #3a2a18;
}

.regist-note a {
  color: #b32025;
  font-weight: 700;
}

.billing-day {
  display: block;
  margin-top: 4px;
  color: #b32025;
  font-weight: 700;
  font-size: 11px;
}

.carrier-banner {
  margin: 0 0 10px;
  padding: 10px;
  font-size: 14px;
  font-weight: 900;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
  border-radius: 3px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
  animation: neonFlicker 3s ease-in-out infinite;
}

.carrier-softbank {
  background: linear-gradient(135deg, #0099cc 0%, #0077aa 50%, #005588 100%);
}

.carrier-docomo {
  background: linear-gradient(135deg, #cc0033 0%, #aa0022 50%, #880011 100%);
}

.carrier-au {
  background: linear-gradient(135deg, #ff6600 0%, #dd4400 50%, #bb3300 100%);
}

/* ---------- ãƒ‰ã‚³ãƒ¢ç™»éŒ²ãƒšã?ã‚¸ãƒ»ã‚­ãƒ£ãƒ³ãƒšã?ãƒ³ã‚¨ãƒªã‚¢ ---------- */
.campaign-area {
  margin: 0 0 20px;
  border-radius: 6px;
  overflow: hidden;
  background-color: #8f1a12;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cg opacity='0.13'%3E%3Ccircle cx='30' cy='18' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='48' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='33' r='9' fill='%23ff6b1a'/%3E%3Ccircle cx='30' cy='33' r='4' fill='%23ffe066'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #8f1a12 0%, #b32025 40%, #7a1010 100%);
  border: 3px solid #e3b93c;
  box-shadow: 0 6px 24px rgba(0,0,0,0.4);
}

.campaign-lights {
  display: flex;
  justify-content: space-around;
  padding: 5px 10px;
  background: rgba(0,0,0,0.15);
  border-bottom: 2px solid rgba(255,215,0,0.3);
}

.campaign-lights span {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #ffe066, #e3b93c);
  box-shadow: 0 0 6px 1px #ffe066;
  animation: blinkLight 1.4s ease-in-out infinite;
}

.campaign-lights span:nth-child(2) { animation-delay: 0.14s; }
.campaign-lights span:nth-child(3) { animation-delay: 0.28s; }
.campaign-lights span:nth-child(4) { animation-delay: 0.42s; }
.campaign-lights span:nth-child(5) { animation-delay: 0.56s; }
.campaign-lights span:nth-child(6) { animation-delay: 0.70s; }
.campaign-lights span:nth-child(7) { animation-delay: 0.84s; }
.campaign-lights span:nth-child(8) { animation-delay: 0.98s; }
.campaign-lights span:nth-child(9) { animation-delay: 1.12s; }
.campaign-lights span:nth-child(10) { animation-delay: 1.26s; }

.campaign-inner {
  padding: 10px 14px 14px;
  text-align: center;
}

.campaign-kikan {
  margin: 0 0 6px;
  font-size: 11px;
  font-weight: 900;
  color: #e3b93c;
  letter-spacing: 0.12em;
  text-shadow: 0 0 8px rgba(227,185,60,0.8);
  animation: neonFlicker 3s ease-in-out infinite;
}

.campaign-copy {
  margin: 0 0 2px;
  font-size: 13px;
  font-weight: 700;
  color: #fff7d6;
  letter-spacing: 0.06em;
}

@keyframes textShine {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

@keyframes starBlink {
  0%, 90%, 100% { opacity: 1; transform: scale(1); }
  95%           { opacity: 0.3; transform: scale(0.7); }
}

@keyframes neonPop {
  0%, 100% {
    color: #fff700;
    text-shadow:
      0 0 2px #fff,
      0 0 8px #fff700,
      0 0 16px #ffcc00;
  }
  50% {
    color: #fff;
    text-shadow:
      0 0 2px #fff,
      0 0 10px #ffe066,
      0 0 20px #ffaa00,
      0 0 32px #ff6600;
  }
}

.campaign-free-badge {
  display: block;
  margin: 6px auto 10px;
  font-size: 26px;
  font-weight: 900;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-align: center;
  color: #fff700;
  text-shadow:
    0 0 2px #fff,
    0 0 8px #fff700,
    0 0 16px #ffcc00;
  animation: neonPop 1.4s ease-in-out infinite;
}

.campaign-free-badge::before,
.campaign-free-badge::after {
  content: "â˜?;
  font-size: 16px;
  margin: 0 6px;
  vertical-align: middle;
  color: #ffe066;
  animation: starBlink 1.6s ease-in-out infinite;
  text-shadow: 0 0 8px #ffcc00, 0 0 16px #ff6600;
}

.campaign-free-badge::after {
  animation-delay: 0.8s;
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.04); }
}

.campaign-copy2 {
  margin: 4px 0 10px;
  font-size: 13px;
  font-weight: 700;
  color: #fff7d6;
  letter-spacing: 0.06em;
}

.campaign-attention {
  padding: 8px 10px;
  font-size: 10px;
  line-height: 1.6;
  color: #e8c96a;
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(227,185,60,0.3);
  border-radius: 4px;
  text-align: left;
}

/* auå°‚ç”¨ä¸Šæ›¸ã?*/
.campaign-area-au {
  background-color: #993300;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cg opacity='0.13'%3E%3Ccircle cx='30' cy='18' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='42' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='48' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='40' r='7' fill='%23ffe066'/%3E%3Ccircle cx='18' cy='26' r='7' fill='%23ffe066'/%3E%3Ccircle cx='30' cy='33' r='9' fill='%23ff6b1a'/%3E%3Ccircle cx='30' cy='33' r='4' fill='%23ffe066'/%3E%3C/g%3E%3C/svg%3E"),
    linear-gradient(180deg, #993300 0%, #cc5500 40%, #882200 100%);
}

.carrier-au-banner {
  margin: 0 0 10px;
  padding: 10px;
  font-size: 14px;
  font-weight: 900;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
  border-radius: 3px;
  background: linear-gradient(135deg, #ff6600 0%, #dd4400 50%, #bb3300 100%);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
  animation: neonFlicker 3s ease-in-out infinite;
}

/* ã‚­ãƒ£ãƒªã‚¢ãƒ­ã‚´?‹ã?ã‚¿ãƒ³ä¸?ä½“ãƒ–ãƒ­ãƒ?‚¯ */
.carrier-regist-block {
  margin: 0 0 12px;
  background: rgba(255,255,255,0.6);
  border: 1px solid rgba(42,26,14,0.1);
  border-radius: 6px;
  padding: 12px 12px 15px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.carrier-logo-wrap {
  text-align: center;
}

/* å°åž‹ã‚­ãƒ£ãƒªã‚¢ãƒãƒƒã‚¸?ˆã?ã‚¿ãƒ³èª¤èªé˜²æ­¢??*/
.carrier-badge {
  display: block;
  margin: 0 0 12px;
  padding: 8px 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-radius: 6px;
  text-align: center;
}

.carrier-badge-docomo {
  background: rgba(204,0,51,0.07);
  color: #aa0022;
  border: 1px solid rgba(204,0,51,0.2);
}

.carrier-badge-au {
  background: rgba(255,102,0,0.07);
  color: #cc4400;
  border: 1px solid rgba(255,102,0,0.2);
}

.carrier-badge-softbank {
  background: rgba(0,102,153,0.07);
  color: #006699;
  border: 1px solid rgba(0,102,153,0.2);
}

.btn-regist-au {
  background: linear-gradient(135deg, #ff6600 0%, #dd4400 100%) !important;
  border-color: #aa2200 !important;
  box-shadow:
    0 6px 16px rgba(255,102,0,0.5),
    inset 0 1px 0 rgba(255,255,255,0.15) !important;
}

.single-course-desc {
  margin: 0 0 16px;
  font-size: 14px;
  font-weight: 700;
  color: #3a2a18;
  text-align: center;
  line-height: 1.7;
}

.single-regist-btn {
  margin: 16px 0;
}

.btn-regist-large {
  display: block;
  width: 100%;
  padding: 15px 20px;
  background: linear-gradient(135deg, #cc0033 0%, #aa0022 100%);
  color: #fff !important;
  font-size: 19px;
  font-weight: 900;
  letter-spacing: 0.15em;
  text-align: center;
  text-decoration: none !important;
  border: 4px solid #880011;
  border-radius: 6px;
  box-shadow:
    0 6px 16px rgba(204,0,51,0.5),
    inset 0 1px 0 rgba(255,255,255,0.15);
  transition: all 0.2s;
  text-shadow: 2px 2px 3px rgba(0,0,0,0.3);
  animation: btnPulse 2.5s ease-in-out infinite;
  cursor: pointer;
  box-sizing: border-box;
}

.btn-regist-large:active {
  transform: translateY(3px);
  box-shadow: 0 3px 8px rgba(204,0,51,0.5);
  animation: none;
}

.btn-regist-large.registered {
  background: linear-gradient(135deg, #888 0%, #666 100%);
  border-color: #444;
  opacity: 0.6;
  cursor: not-allowed;
  animation: none;
}

.regist-note-small {
  margin: 12px 0 0;
  font-size: 11px;
  line-height: 1.7;
  color: #3a2a18;
}

.regist-note-small a {
  color: #b32025;
  font-weight: 700;
}

.course-title {
  margin: 0 0 14px;
  padding: 10px;
  font-size: 17px;
  font-weight: 900;
  color: #fff7d6;
  text-align: center;
  letter-spacing: 0.08em;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  border-radius: 3px;
  box-shadow: 0 4px 12px rgba(179,32,37,0.3);
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}

.course-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0 0 20px;
}

.course-card {
  display: block;
  padding: 14px 16px;
  background: linear-gradient(135deg, #fff7d6 0%, #ffe8a0 100%);
  border: 3px solid #c8a030;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(200,160,48,0.4);
  text-decoration: none !important;
  transition: all 0.2s;
}

.course-card:active {
  transform: translateY(2px);
  box-shadow: 0 2px 6px rgba(200,160,48,0.4);
}

.card-point {
  margin: 0 0 8px;
  font-size: 24px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.05em;
  text-shadow: 
    1px 1px 0 rgba(179,32,37,0.2),
    0 0 15px rgba(255,235,59,0.6);
}

.card-price {
  font-size: 14px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.6;
}

.free-tag {
  display: inline-block;
  padding: 3px 10px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  border-radius: 10px;
  margin-right: 6px;
  box-shadow: 0 2px 6px rgba(179,32,37,0.3);
  text-shadow: 1px 1px 1px rgba(0,0,0,0.3);
}

.course-card.registered {
  opacity: 0.5;
  background: linear-gradient(135deg, #e8e8e8 0%, #d0d0d0 100%);
  border-color: #999;
  pointer-events: none;
}

.registered-label {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(179,32,37,0.2);
  color: #b32025;
  font-size: 11px;
  font-weight: 900;
  border-radius: 10px;
  border: 2px solid rgba(179,32,37,0.3);
  margin-left: 8px;
}

.info-section {
  margin: 20px 0 0;
  padding: 12px 0 0;
  border-top: 2px dashed rgba(179,32,37,0.3);
}

.info-section h3 {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 900;
  color: #3a2a18;
}

.info-section a,
.info-link a {
  display: inline-block;
  padding: 8px 12px;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(42,26,14,0.2);
  border-radius: 3px;
  color: #0099cc !important;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none !important;
}

/* ---------- ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ?---------- */
@media (max-width: 480px) {
  .sub-main {
    padding: 16px 13px 36px;
  }

  .contents {
    padding: 18px 13px 20px;
  }

  input[type="submit"],
  button[type="submit"] {
    font-size: 15px;
    padding: 14px 16px;
    min-height: 50px;
  }
}

/* ---------- ãƒ­ã‚°ã‚¤ãƒ³NG??Dãƒ­ã‚°ã‚¤ãƒ³?‰ã?ãƒ¼ã‚¸ ---------- */
.login-ng-notice {
  margin: 0 0 10px;
  padding: 10px 14px;
  font-size: 14px;
  font-weight: 900;
  color: #b32025;
  background: rgba(179,32,37,0.07);
  border-left: 4px solid #b32025;
  border-radius: 3px;
}

.login-ng-text {
  margin: 0 0 16px;
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.8;
}

.login-ng-alert {
  margin: 0 0 16px;
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  line-height: 1.8;
  background: rgba(227,185,60,0.12);
  border: 2px solid #e3b93c;
  border-radius: 4px;
}

.login-ng-btn {
  display: block;
  padding: 16px;
  margin: 0 0 20px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6 !important;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-align: center;
  text-decoration: none !important;
  border: 3px solid #7a1010;
  border-radius: 5px;
  box-shadow: 0 5px 14px rgba(179,32,37,0.4);
  animation: btnPulse 2.5s ease-in-out infinite;
}

.login-ng-btn:active {
  transform: translateY(2px);
  animation: none;
}

.login-ng-forget {
  padding: 14px;
  background: rgba(255,255,255,0.5);
  border: 1px solid rgba(42,26,14,0.12);
  border-radius: 4px;
}

.login-ng-forget p {
  margin: 0 0 10px;
  font-size: 12px;
  color: #3a2a18;
  line-height: 1.8;
}

.login-ng-inquiry {
  display: block;
  padding: 11px 14px;
  background: linear-gradient(135deg, #2a1a0e 0%, #1a0a04 100%);
  color: #e3b93c !important;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-align: center;
  text-decoration: none !important;
  border: 2px solid #e3b93c;
  border-radius: 4px;
  box-shadow: 0 3px 10px rgba(0,0,0,0.2);
}

.login-ng-ad {
  margin: 20px 0;
  text-align: center;
}

/* ---------- IDãƒ­ã‚°ã‚¤ãƒ³ãƒ•ã‚©ãƒ¼ãƒ? ---------- */
.login-id-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.login-id-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.login-id-label {
  font-size: 12px;
  font-weight: 900;
  color: #3a2a18;
  letter-spacing: 0.08em;
  padding-left: 2px;
}

.login-id-input {
  width: 100%;
  padding: 13px 14px;
  font-size: 16px;
  color: #2b2b2b;
  background: #fffdf5;
  border: 2px solid #2a1a0e;
  border-radius: 4px;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.08);
  box-sizing: border-box;
  -webkit-appearance: none;
}

.login-id-input:focus {
  outline: none;
  border-color: #e3b93c;
  box-shadow: 0 0 0 3px rgba(227,185,60,0.25), inset 0 2px 4px rgba(0,0,0,0.08);
}

.login-id-submit {
  margin-top: 4px;
}

.login-id-btn {
  display: block;
  width: 100%;
  padding: 16px;
  background: linear-gradient(135deg, #b32025 0%, #8d1a12 100%);
  color: #fff7d6;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0.15em;
  text-align: center;
  border: 3px solid #7a1010;
  border-radius: 5px;
  box-shadow: 0 5px 14px rgba(179,32,37,0.4);
  cursor: pointer;
  -webkit-appearance: none;
  animation: btnPulse 2.5s ease-in-out infinite;
}

.login-id-btn:active {
  transform: translateY(2px);
  box-shadow: 0 2px 6px rgba(179,32,37,0.4);
  animation: none;
}
.login-info-table {
  width: 100%;
  border-collapse: collapse;
  border: 3px solid #2a1a0e;
  border-radius: 5px;
  overflow: hidden;
  margin: 14px 0 0;
  box-shadow: 3px 3px 0 rgba(42,26,14,0.15);
}

.login-info-table tr {
  border-bottom: 2px solid #2a1a0e;
}

.login-info-table tr:last-child {
  border-bottom: none;
}

.login-info-table th {
  width: 100px;
  padding: 14px 12px;
  font-size: 12px;
  font-weight: 900;
  color: #fff7d6;
  letter-spacing: 0.05em;
  text-align: left;
  vertical-align: middle;
  background: linear-gradient(135deg, #2a1a0e 0%, #1a0a04 100%);
  border-right: 2px solid #e3b93c;
  white-space: nowrap;
}

.login-info-table td {
  padding: 14px 14px;
  font-size: 15px;
  font-weight: 900;
  color: #b32025;
  letter-spacing: 0.05em;
  vertical-align: middle;
  background: #fffdf5;
  word-break: break-all;
}
.login-lead-text {
  margin: 0 0 18px;
  font-size: 13px;
  font-weight: 700;
  color: #3a2a18;
  text-align: center;
}

.login-carriers {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0 0 24px;
}

.login-carrier-block {
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 14px rgba(0,0,0,0.2);
}

.login-carrier-label {
  padding: 8px 14px;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.12em;
  color: #fff;
  text-align: center;
  text-shadow: 1px 1px 3px rgba(0,0,0,0.3);
}

.login-carrier-sub {
  margin: 0;
  padding: 6px 14px;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,0.85);
  text-align: center;
}

.login-carrier-btn {
  display: block;
  width: 100%;
  margin: 0;
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-align: center;
  text-decoration: none !important;
  border: none;
  border-top: 1px solid rgba(255,255,255,0.15);
  cursor: pointer;
  transition: opacity 0.15s;
  box-sizing: border-box;
}

.login-carrier-btn:active {
  opacity: 0.75;
}

/* docomo */
.login-docomo {
  background: linear-gradient(135deg, #cc0033 0%, #aa0022 100%);
}

.login-btn-docomo {
  background: rgba(0,0,0,0.18);
  color: #fff !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.4);
}

/* au */
.login-au {
  background: linear-gradient(135deg, #ff6600 0%, #cc4400 100%);
}

.login-btn-au {
  background: rgba(0,0,0,0.18);
  color: #fff !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.4);
}

/* SoftBank */
.login-softbank {
  background: linear-gradient(135deg, #0099cc 0%, #006699 100%);
}

.login-btn-softbank {
  background: rgba(0,0,0,0.18);
  color: #fff !important;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.4);
}
