/* @override 
	http://localhost:8888/go2/app/css/touroku.css
	http://localhost:8888/go3/app/css/touroku.css
	https://gokaku-nurse.com/app/css/touroku.css */


/*登録ページ関連*/
.touroku_main {
	background-color: white;
}
.name_sei {
	width: 45%;
	display: inline-block;
}
.name_mei {
	width: 45%;
	display: inline-block;
}
.tel_box {
	width: 91%;
	display: inline-block;
}
.birth {
	width: 45%;
	display: inline-block;
}
.post_code {
	width: 45%;
	display: inline-block;
}
.seibetu {
	display: inline-block;
	width: 2em;
	float: left;
	height: 2em;
}
.seibetu_txt {
	height: 2em;
	float: left;
	line-height: 2em;
	margin-right: 2em;
}
.ID_box {
	margin-top: 0.5em;
	background-color: #f9f9f9;
	padding: 1em;
	border-radius: 8px;
}
.login_id_txt {
color: gray;
font-size: 1.2em;
}

.hissu {
	color: red;
}
.error_txt {
	color: red;
	line-height: 4em;
	font-size: 1.25em;
}
.kari_box {
margin-top: 2rem;
padding: 1rem;
background-color: #f9f9f9;
border-radius: 8px;
}
.c-body_txt {
	margin-bottom: 1.5rem;
	line-height: 2rem;
	font-size: 1em;
}

.confirmation_button {
            background-color: #4CAF50;
            color: white;
            padding: 10px 15px;
            border: none;
            border-radius: 8px;
            cursor: pointer;
            width: 100%;
			margin-top: 1rem;
}
.confirmation_button:hover {
            background-color: #45a049;
        }
 
 
 
 /*プルダウン          */
:root {
      --primary-color: #FFBCcc;
      --text-color: #333;
      --border-color: #e0e0e0;
      --hover-color: #fff5f8;
      --focus-shadow: 0 0 0 3px rgba(255, 188, 204, 0.3);
    }

    body {
      font-family: 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
      color: var(--text-color);

    }

    .form-group {
      margin-bottom: 24px;
	}

    .form-label {
      display: block;
      margin-bottom: 8px;
      font-weight: 600;
      font-size: 14px;
    }


    .date-selects {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }

    .select-wrapper {
      position: relative;
      min-width: 100px;
    }

    .select-wrapper::after {
      content: '';
      position: absolute;
      right: 12px;
      top: 50%;
      transform: translateY(-50%);
      width: 0;
      height: 0;
      border-left: 5px solid transparent;
      border-right: 5px solid transparent;
      border-top: 6px solid var(--primary-color);
      pointer-events: none;
    }

    select {
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      width: 100%;
      padding: 9px 35px 9px 15px;
      font-size: 15px;
      border: 1px solid var(--border-color);
      border-radius: 8px;
      background-color: white;
      cursor: pointer;
      transition: all 0.2s ease;
    }

    select:hover {
      background-color: var(--hover-color);
    }

    select:focus {
      outline: none;
      border-color: var(--primary-color);
      box-shadow: var(--focus-shadow);
    }

    .date-unit {
      margin-left: 4px;
      font-size: 14px;
      color: #666;
      align-self: center;
    }

    /* ホバー効果をテキストボックスにも適用 */
    input[type="text"],
    input[type="password"],
    input[type="email"],
    input[type="tel"] {
      transition: all 0.2s ease;
    }

    input[type="text"]:hover,
    input[type="password"]:hover,
    input[type="email"]:hover,
    input[type="tel"]:hover {
      background-color: var(--hover-color);
    }

    input[type="text"]:focus,
    input[type="password"]:focus,
    input[type="email"]:focus,
    input[type="tel"]:focus {
      outline: none;
      border-color: var(--primary-color);
      box-shadow: var(--focus-shadow);
    }

    /* カスタムスタイルフォーモバイル */
    @media (max-width: 576px) {
      .date-selects {
        gap: 8px;
      }
      
      .select-wrapper {
        min-width: 80px;
      }
      
      select {
        padding: 10px 30px 10px 12px;
        font-size: 14px;
      }
    }



/*決済ページ関連*/
        body {
            margin: 0;
        }
        .container {
            max-width: 500px;
            margin: 0 auto;
            background-color: white;
            padding: 20px;
            border-radius: 8px;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
	.card-number-container {
		display: flex;
		gap: 10px;
		margin-bottom: 15px;
		max-width: 300px;
	}
		.card-number-container input {
		width: 20%;
		text-align: center;
	}
	.expire-container {
		display: flex;
		align-items: center;
		gap: 10px;
		margin-bottom: 15px;
		max-width: 200px;
	}
	.expire-container input {
		width: 20%;
		text-align: center;
	}
		.message {
		margin-top: 15px;
		padding: 10px;
		border-radius: 4px;
	}
	#securityCode {
		max-width: 120px;
		text-align: center;
	}
	.success {
		background-color: #dff0d8;
		color: #3c763d;
		border: 1px solid #d6e9c6;
	}
	.error {
		background-color: #f2dede;
		color: #a94442;
		border: 1px solid #ebccd1;
	}
	.info {
		background-color: #d9edf7;
		color: #31708f;
		border: 1px solid #bce8f1;
	}
	/* ローディングインジケーター */
	.loading {
		display: inline-block;
		width: 20px;
		height: 20px;
		border: 3px solid rgba(0,0,0,.1);
		border-radius: 50%;
		border-top-color: #007bff;
		animation: spin 1s ease-in-out infinite;
		margin-right: 10px;
	}
	@keyframes spin {
		to { transform: rotate(360deg); }
	}
        label {
            display: block;
            margin-bottom: 5px;
            font-weight: bold;
        }
        input {
            width: 100%;
            padding: 8px;
            border: 1px solid #ddd;
            border-radius: 8px;
            box-sizing: border-box;
			font-size: 1rem;
		}
        button {
            background-color: #4CAF50;
            color: white;
            padding: 10px 15px;
            border: none;
            border-radius: 8px;
            cursor: pointer;
            width: 100%;
		}
        button:hover {
            background-color: #45a049;
        }
        button:disabled {
            background-color: #cccccc;
            cursor: not-allowed;
        }
        .message {
            margin-top: 15px;
            padding: 10px;
            border-radius: 8px;
			margin-bottom: 15px;
		}
        .success {
            background-color: #dff0d8;
            color: #3c763d;
            border: 1px solid #d6e9c6;
        }
        .error {
            background-color: #f2dede;
            color: #a94442;
            border: 1px solid #ebccd1;
        }
        #debug-info {
            margin-top: 20px;
            padding: 10px;
            background-color: #f8f9fa;
            border: 1px solid #dee2e6;
            border-radius: 8px;
            font-family: monospace;
            font-size: 12px;
            display: none;
        }
 /*決済関連ここまで*/